2021-07-05 10:03:08 +03:00
# Установка ALT Linux в ostree
2021-07-13 16:20:54 +03:00
Для установки достаточно раздела 2ГБ.
2021-07-05 10:03:08 +03:00
2021-07-13 16:20:54 +03:00
Сборка архива корневой файловой системы
2021-07-05 10:03:08 +03:00
```
2021-07-13 16:20:54 +03:00
git clone https://gitea.basealt.ru/keremet/mkimage-profiles
2021-07-05 10:03:08 +03:00
cd mkimage-profiles
2021-07-13 16:20:54 +03:00
mkdir ~/out
make vm/acos.tar
cd -
```
Создание ветки в репозитории ostree
```
2021-07-05 10:03:08 +03:00
mkdir root
2021-08-03 14:10:28 +03:00
sudo tar xf out/acos-latest-x86_64.tar -C root/ --exclude=./dev/tty --exclude=./dev/tty0 --exclude=./dev/console --exclude=./dev/urandom --exclude=./dev/random --exclude=./dev/full --exclude=./dev/zero --exclude=/dev/null --exclude=./dev/pts/ptmx --exclude=./dev/null
2021-08-06 17:19:58 +03:00
sudo chroot root/ systemctl enable ignition-firstboot-complete.service ostree-remount.service sshd docker
2021-08-03 14:10:28 +03:00
sudo sed -i 's/^LABEL=ROOT\t/LABEL=boot\t/g' root/etc/fstab
2021-08-03 16:28:54 +03:00
sudo sed -i 's/^AcceptEnv /#AcceptEnv /g' root/etc/openssh/sshd_config
2021-08-03 16:29:53 +03:00
sudo sed -i 's/^# WHEEL_USERS ALL=(ALL) ALL$/WHEEL_USERS ALL=(ALL) ALL/g' root/etc/sudoers
2021-08-06 17:19:58 +03:00
sudo sed -i 's|^HOME=/home$|HOME=/var/home|g' root/etc/default/useradd
2021-08-03 15:29:43 +03:00
echo "blacklist floppy" | sudo tee root/etc/modprobe.d/blacklist-floppy.conf
2021-08-03 14:10:28 +03:00
sudo mkdir root/sysroot
sudo ln -s sysroot/ostree root/ostree
2021-08-06 17:19:58 +03:00
sudo mv root/home root/opt root/srv root/mnt root/var/
sudo mv root/root root/var/roothome
sudo mv root/usr/local root/var/usrlocal
sudo ln -s var/home root/home
sudo ln -s var/opt root/opt
sudo ln -s var/srv root/srv
sudo ln -s var/roothome root/root
sudo ln -s ../var/usrlocal root/usr/local
sudo ln -s var/mnt root/mnt
sudo chroot root/ chgrp wheel /usr/bin/sudo /bin/su
2021-08-03 14:10:28 +03:00
sudo chroot root/ chmod 710 /usr/bin/sudo /bin/su
sudo chroot root/ chmod ug+s /usr/bin/sudo /bin/su
KERNEL=`sudo find root/boot/ -type f -name "vmlinuz-*"`
SHA=`sudo sha256sum "$KERNEL" | awk '{print $1;}'`
sudo mv "$KERNEL" "$KERNEL-$SHA"
sudo rm -f root/boot/vmlinuz
sudo rm -f root/boot/initrd*
2021-08-06 17:19:58 +03:00
cat < < EOF > /tmp/ostree.conf
d /run/ostree 0755 root root -
f /run/ostree/initramfs-mount-var 0755 root root -
EOF
sudo cp /tmp/ostree.conf root/
sudo chroot root/ dracut --reproducible --gzip -v --add ignition --add ostree -f /boot/initramfs-$SHA --include /ostree.conf /etc/tmpfiles.d/ostree.conf --no-hostonly --omit-drivers=floppy --omit=nfs --omit=lvm --omit=iscsi --kver `ls root/lib/modules`
sudo rm -f root/ostree.conf
2021-07-13 16:20:54 +03:00
2021-08-03 14:10:28 +03:00
sudo rm -rf root/usr/etc
sudo mv root/etc root/usr/etc
2021-07-13 16:20:54 +03:00
2021-08-06 17:19:58 +03:00
sudo mv root/var ./var
sudo mkdir root/var
2021-08-03 14:10:28 +03:00
ostree init --repo=repo --mode=archive
sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --no-xattrs --no-bindings --parent=none --mode-ro-executables --add-metadata-string=version=sisyphus.`date +%Y%m%d`.0.0
2021-07-05 10:03:08 +03:00
```
2021-07-13 16:20:54 +03:00
Последняя команда выдаст хеш коммита. Н а коммит можно ссылаться по этому хешу или по имени ветки (параметр -b).
2021-07-05 10:03:08 +03:00
2021-08-03 14:10:28 +03:00
Н а диске, на который выполняется установка (в данном примере /dev/sdb) создать файловую систему и минимальный набор каталогов для ostree. Метка boot нужна для поиска раздела в ignition.
2021-07-05 10:03:08 +03:00
```
2021-07-13 16:20:54 +03:00
DEVICE=/dev/sdb
2021-07-19 19:28:31 +03:00
sudo parted $DEVICE mktable msdos
2021-07-23 10:08:05 +03:00
sudo parted -a optimal $DEVICE mkpart primary ext4 2MIB 100%
2021-07-19 19:28:31 +03:00
sudo parted $DEVICE set 1 boot on
2021-08-03 14:10:28 +03:00
sudo mkfs.ext4 -L boot "$DEVICE"1
2021-07-19 19:28:31 +03:00
sudo mkdir /tmp/acos
2021-07-23 10:08:05 +03:00
sudo mount "$DEVICE"1 /tmp/acos
2021-07-19 19:28:31 +03:00
sudo ostree admin init-fs --modern /tmp/acos
2021-07-05 10:03:08 +03:00
```
2021-07-23 10:08:05 +03:00
Установить GRUB
```
sudo grub-install --root-directory=/tmp/acos $DEVICE
sudo ln -s ../loader/grub.cfg /tmp/acos/boot/grub/grub.cfg
```
2021-07-13 16:20:54 +03:00
Выполнить развертывание операционной системы из репозитория ostree.
2021-07-05 10:03:08 +03:00
```
2021-07-19 19:28:31 +03:00
sudo ostree pull-local --repo /tmp/acos/ostree/repo /home/keremet/repo alt/x86_64/coreos/stable
2021-07-23 10:08:05 +03:00
sudo ostree config --repo /tmp/acos/ostree/repo set sysroot.bootloader grub2
2021-07-19 19:28:31 +03:00
sudo ostree refs --repo /tmp/acos/ostree/repo --create alt:alt/x86_64/coreos/stable alt/x86_64/coreos/stable
sudo ostree admin os-init alt-coreos --sysroot /tmp/acos
2021-08-03 14:10:28 +03:00
OSTREE_BOOT_PARTITION="/boot" sudo ostree admin deploy alt:alt/x86_64/coreos/stable --sysroot /tmp/acos --os alt-coreos --karg-append=ignition.platform.id=metal --karg-append=\$ignition_firstboot --karg-append=quiet --karg-append=root=UUID=`sudo blkid --match-tag UUID -o value "$DEVICE"1`
2021-08-06 17:19:58 +03:00
sudo rm -r /tmp/acos/ostree/deploy/alt-coreos/var
sudo mv var /tmp/acos/ostree/deploy/alt-coreos/var
sudo touch /tmp/acos/ostree/deploy/alt-coreos/var/.ostree-selabeled
2021-07-05 10:03:08 +03:00
```
2021-07-23 10:08:05 +03:00
Установить пароль рута в новой системе
2021-07-05 10:03:08 +03:00
```
2021-07-23 10:08:05 +03:00
sudo chroot /tmp/acos/ostree/boot.1/alt-coreos/*/0/ passwd
2021-07-05 10:03:08 +03:00
```
2021-08-03 14:10:28 +03:00
Создать конфигурационные файлы ignition
```
sudo mkdir /tmp/acos/ignition
sudo cp config.ign /tmp/acos/ignition/
sudo touch /tmp/acos/boot/ignition.firstboot
```
2021-07-23 10:08:05 +03:00
-----------------------------------------
2021-07-05 10:03:08 +03:00
2021-07-23 10:08:05 +03:00
В случае каких-то ошибок для повтора инструкции можно восстановить исходное состояние
2021-07-05 10:03:08 +03:00
```
2021-07-23 10:08:05 +03:00
DEVICE=/dev/sdb
sudo rm -rf repo/ root/
sudo umount /tmp/acos
2021-08-03 14:10:28 +03:00
sudo rm -rf /tmp/acos
2021-07-23 10:08:05 +03:00
sudo dd if=/dev/zero of=$DEVICE bs=1M
2021-07-05 10:03:08 +03:00
```