]> code.delx.au - monosys/blob - notes/desktop:debian-bookworm.txt
745a71c2022820b9fb10d813c8dd2232e95bb207
[monosys] / notes / desktop:debian-bookworm.txt
1 THE_DEV=/dev/sda
2 THE_HOSTNAME=somehost
3 THE_USERNAME=someuser
4
5
6 gdisk $THE_DEV
7 ESP 200M ef00
8 XBOOTLDR 824M
9 LUKSROOT
10
11
12 vgcreate $THE_HOSTNAME /dev/disk/by-partlabel/LUKSROOT
13 lvcreate -L16G -nswap $THE_HOSTNAME
14 lvcreate -l100%FREE -nroot $THE_HOSTNAME
15
16 mount /dev/mapper/$THE_HOSTNAME-root /mnt/
17 cd /mnt/
18 btrfs fi label /mnt/ btrfsroot
19 btrfs subv create @root
20 btrfs subv set-default /mnt/@root
21 btrfs subv create @home
22 btrfs subv create @apt
23 btrfs subv create @vartmp
24 chmod 1777 @vartmp
25 umount /mnt/
26 mount /dev/mapper/$THE_HOSTNAME-root /mnt/
27
28 mkdir -p /mnt/etc/
29 cat <<EOT > /mnt/etc/fstab
30 LABEL=btrfsroot / btrfs subvol=@root,discard,compress,nodev 0 0
31 LABEL=btrfsroot /btrfs btrfs subvol=/,discard,compress,nodev,nosuid 0 0
32 LABEL=btrfsroot /home btrfs subvol=@home,discard,compress,nodev,nosuid 0 0
33 LABEL=btrfsroot /var/cache/apt btrfs subvol=@apt,discard,compress,nodev,nosuid 0 0
34 LABEL=btrfsroot /var/tmp btrfs subvol=@vartmp,discard,compress,nodev,nosuid 0 0
35 PARTLABEL=XBOOTLDR /boot ext4 discard,nodev,nosuid,noexec 0 0
36 PARTLABEL=ESP /boot/efi vfat discard,nodev,nosuid,noexec 0 0
37 LABEL=swap swap swap discard 0 0
38 tmpfs /tmp tmpfs nosuid,nodev 0 0
39 EOT
40
41
42 debootstrap bookworm /mnt/ https://deb.debian.org/debian
43
44 cat <<EOT > /mnt/etc/apt/sources.list
45 deb https://deb.debian.org/debian bookworm main contrib non-free non-free-firmware
46 deb https://deb.debian.org/debian bookworm-updates main contrib non-free non-free-firmware
47 deb https://deb.debian.org/debian-security bookworm-security main contrib non-free non-free-firmware
48 EOT
49
50
51 for i in /dev /proc /sys /run /tmp; do mount --rbind $i /mnt$i; done
52 chroot /mnt/
53 mkdir -p /btrfs/ /boot/efi/ /home/ /var/cache/apt/ /var/tmp/
54
55
56 mkdir /run/systemd/resolve/
57 [ -f /run/systemd/resolve/stub-resolv.conf ] || echo 'nameserver 1.1.1.1' > /run/systemd/resolve/stub-resolv.conf
58
59
60 echo $THE_HOSTNAME > /etc/hostname
61 ln -sf /usr/share/zoneinfo/Australia/Sydney /etc/localtime
62 echo do_symlinks=no > /etc/kernel-img.conf
63
64
65 dpkg-reconfigure locales
66 apt-get install aptitude curl git python3 vim
67
68
69 cd /root/
70 curl -sSfL https://code.delx.au/p/dotfiles | bash
71 exit
72
73
74 chroot /mnt/
75 cd /root
76
77 mkdir /root/bin/
78 git clone https://code.delx.au/monosys
79 ln -s /root/monosys/bin /root/bin/monosys-bin
80
81 mkdir /root/monosys/package-lists/local
82 ln -s /root/monosys/package-lists/local /root/.aptorphan
83 cd /root/monosys/package-lists/local
84 for i in base base-hw desktop-base desktop-gnome desktop-gnome-software desktop-plymouth desktop-printing filesystems multimedia-players wifi; do ln -s ../debian/$i; done
85 cp ../debian/system-efi-amd64 .
86
87 apt-get update
88 aptorphan
89
90 systemctl disable ssh
91 find /etc/systemd/system -xtype l -delete
92
93 mv /etc/default/grub{,.bak}
94 cp /root/monosys/etc/default/grub /etc/default/grub
95 grub-install
96 update-grub
97
98 passwd root
99 adduser $THE_USER
100 gpasswd -a $THE_USER sudo
101
102 plymouth-set-default-theme spinner
103
104
105
106 # reboot
107
108 flatpak remote-add flathub https://dl.flathub.org/repo/flathub.flatpakrepo