From 7fef5ae49f2baa6694a49e76af561bb7d72f7e34 Mon Sep 17 00:00:00 2001 From: Andrey Sokolov Date: Fri, 23 Jul 2021 10:08:05 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A1=D0=BA=D0=BE=D1=80=D1=80=D0=B5=D0=BA?= =?UTF-8?q?=D1=82=D0=B8=D1=80=D0=BE=D0=B2=D0=B0=D0=BD=D1=8B=20=D1=81=D0=B1?= =?UTF-8?q?=D0=BE=D1=80=D0=BA=D0=B0=20=D0=B8=20=D0=BE=D0=B1=D0=BD=D0=BE?= =?UTF-8?q?=D0=B2=D0=BB=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BF=D0=BE=D0=B4=20ost?= =?UTF-8?q?ree-2013.alt1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- alt_on_ostree.md | 58 ++++++++++++++++++------------------------------ upgrade_acos.md | 38 ++++++++++++++----------------- 2 files changed, 39 insertions(+), 57 deletions(-) diff --git a/alt_on_ostree.md b/alt_on_ostree.md index e0d77d8..512236c 100644 --- a/alt_on_ostree.md +++ b/alt_on_ostree.md @@ -2,14 +2,6 @@ Для установки достаточно раздела 2ГБ. -Потребуется GRUB с поддержкой команды blscfg -``` -wget http://git.altlinux.org/tasks/279741/build/100/x86_64/rpms/grub-common-2.06-alt2.rc1.x86_64.rpm -wget http://git.altlinux.org/tasks/279741/build/100/x86_64/rpms/grub-efi-2.06-alt2.rc1.x86_64.rpm -wget http://git.altlinux.org/tasks/279741/build/100/x86_64/rpms/grub-pc-2.06-alt2.rc1.x86_64.rpm -sudo apt-get install grub-common-2.06-alt2.rc1.x86_64.rpm grub-efi-2.06-alt2.rc1.x86_64.rpm grub-pc-2.06-alt2.rc1.x86_64.rpm -``` - Сборка архива корневой файловой системы ``` git clone https://gitea.basealt.ru/keremet/mkimage-profiles @@ -24,11 +16,9 @@ cd - ostree init --repo=repo --mode=archive mkdir root 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 -sudo apt-get install -o "RPM::RootDir=$PWD/root" grub-common-2.06-alt2.rc1.x86_64.rpm grub-efi-2.06-alt2.rc1.x86_64.rpm grub-pc-2.06-alt2.rc1.x86_64.rpm mkdir root/sysroot ln -s sysroot/ostree root/ostree rm -rf root/usr/etc -sed -i '3a\LABEL=BOOT\t/boot\text4\tdefaults\t0\t0' root/etc/fstab mv root/etc root/usr/etc KERNEL=`find root/boot/ -type f -name "vmlinuz-*"` @@ -38,7 +28,7 @@ rm -f root/boot/vmlinuz rm -f root/boot/initrd* sudo chroot root/ dracut --reproducible --gzip -v --add ostree -f /boot/initramfs-$SHA --no-hostonly --omit=nfs --omit=lvm --omit=iscsi --kver `ls root/lib/modules` -sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --owner-uid 0 --owner-gid 0 --no-xattrs --no-bindings --parent=none --mode-ro-executables +sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --owner-uid 0 --owner-gid 0 --no-xattrs --no-bindings --parent=none --mode-ro-executables --add-metadata-string=version=sisyphus.`date +%Y%m%d`.0.0 ``` Последняя команда выдаст хеш коммита. На коммит можно ссылаться по этому хешу или по имени ветки (параметр -b). @@ -47,45 +37,41 @@ sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --ow ``` DEVICE=/dev/sdb sudo parted $DEVICE mktable msdos -sudo parted -a optimal $DEVICE mkpart primary ext4 2MIB 20% +sudo parted -a optimal $DEVICE mkpart primary ext4 2MIB 100% sudo parted $DEVICE set 1 boot on -sudo mkfs.ext4 -L BOOT "$DEVICE"1 - -sudo parted -a optimal $DEVICE mkpart primary ext4 20% 100% -sudo mkfs.ext4 -L ROOT "$DEVICE"2 - +sudo mkfs.ext4 -L ROOT "$DEVICE"1 sudo mkdir /tmp/acos -sudo mount "$DEVICE"2 /tmp/acos - -sudo mkdir /tmp/acos/boot -sudo mount "$DEVICE"1 /tmp/acos/boot +sudo mount "$DEVICE"1 /tmp/acos sudo ostree admin init-fs --modern /tmp/acos ``` -Выполнить развертывание операционной системы из репозитория ostree. -``` -sudo ostree pull-local --repo /tmp/acos/ostree/repo /home/keremet/repo alt/x86_64/coreos/stable -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 -sudo ostree admin deploy alt:alt/x86_64/coreos/stable --sysroot /tmp/acos --os alt-coreos --karg-append=quiet --karg-append=root=UUID=`sudo blkid --match-tag UUID -o value "$DEVICE"2` -``` - Установить GRUB ``` sudo grub-install --root-directory=/tmp/acos $DEVICE +sudo ln -s ../loader/grub.cfg /tmp/acos/boot/grub/grub.cfg ``` -Конфиг GRUB /tmp/acos/boot/grub/grub.cfg заполнить следующим содержимым: +Выполнить развертывание операционной системы из репозитория ostree. ``` -function load_video { - insmod all_video -} -set root='hd0,msdos1' -set timeout=5 -blscfg +sudo ostree pull-local --repo /tmp/acos/ostree/repo /home/keremet/repo alt/x86_64/coreos/stable +sudo ostree config --repo /tmp/acos/ostree/repo set sysroot.bootloader grub2 +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 +OSTREE_BOOT_PARTITION="/boot" sudo ostree admin deploy alt:alt/x86_64/coreos/stable --sysroot /tmp/acos --os alt-coreos --karg-append=quiet --karg-append=root=UUID=`sudo blkid --match-tag UUID -o value "$DEVICE"1` ``` Установить пароль рута в новой системе ``` sudo chroot /tmp/acos/ostree/boot.1/alt-coreos/*/0/ passwd ``` + +----------------------------------------- + +В случае каких-то ошибок для повтора инструкции можно восстановить исходное состояние +``` +DEVICE=/dev/sdb +sudo rm -rf repo/ root/ +sudo umount /tmp/acos +rm -rf /tmp/acos +sudo dd if=/dev/zero of=$DEVICE bs=1M +``` diff --git a/upgrade_acos.md b/upgrade_acos.md index 06385c3..b5bcb01 100644 --- a/upgrade_acos.md +++ b/upgrade_acos.md @@ -1,28 +1,28 @@ # Обновление ALT Linux в ostree -На сервере в ветке, из которой была установлена ОС в ostree [подробнее об установке](alt_on_ostree.md), создать новый коммит. Для этого внести изменения в каталог root и вызвать ostree commit без параметра --parent=none. Например так: +На сервере в ветке, из которой была установлена ОС в ostree [подробнее об установке](alt_on_ostree.md), создать новый коммит. Для этого внести изменения в каталог root и вызвать ostree commit без параметра --parent=none. Указать версию. Например так: ``` touch root/usr/bin/privet chmod a+x root/usr/bin/privet echo "echo Privet" > root/usr/bin/privet -sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --owner-uid 0 --owner-gid 0 --no-xattrs --no-bindings --mode-ro-executables +sudo ostree commit --repo=repo --tree=dir=root -b alt/x86_64/coreos/stable --owner-uid 0 --owner-gid 0 --no-xattrs --no-bindings --mode-ro-executables --add-metadata-string=version=sisyphus.`date +%Y%m%d`.0.1 ``` Результат можно будет проверить следующими командами: ``` [keremet@host-15 ~]$ ostree log --repo=repo alt/x86_64/coreos/stable -commit 0adc3481f84764b4139a2e3ebd6cb351e15d69208e526327e5d3c8fddf1cafd9 -Parent: 4e1b4eb4512bd032b91a3a65c396d853e3a94033e07f75ed2f0faba23b7a77a2 -ContentChecksum: e2f5cc4672915f5dcaf5d315a0678237deacf9824ae96f0c430e170cf6887940 -Date: 2021-07-19 16:19:57 +0000 +commit ef1232b040e3f4d812c61c0e6b5faac4dfafcee4aa3efbc5399a39b555ffdcd9 +Parent: 6a20a507690294aa2787257a22a3830ee7c19195136924b84ee3fb5de2c6774e +ContentChecksum: 23c3a3fdb9e98fcb05893d04f3df6e2af65e191bb890d0db174986e3df1a84e8 +Date: 2021-07-22 10:09:21 +0000 (no subject) -commit 4e1b4eb4512bd032b91a3a65c396d853e3a94033e07f75ed2f0faba23b7a77a2 -ContentChecksum: a2e31383521e4025c6341878cf4362b8973529102ece596e2f675577a8412301 -Date: 2021-07-19 16:13:12 +0000 +commit 6a20a507690294aa2787257a22a3830ee7c19195136924b84ee3fb5de2c6774e +ContentChecksum: 2e61f9a95768f3124ddca76676c66582172067748030311ac742f9db9dcc8822 +Date: 2021-07-22 09:57:43 +0000 (no subject) -[keremet@host-15 ~]$ ostree diff --repo=repo 4e1b4eb4512bd032b91a3a65c396d853e3a94033e07f75ed2f0faba23b7a77a2 0adc3481f84764b4139a2e3ebd6cb351e15d69208e526327e5d3c8fddf1cafd9 +[keremet@host-15 ~]$ ostree diff --repo=repo 6a20a507690294aa2787257a22a3830ee7c19195136924b84ee3fb5de2c6774e ef1232b040e3f4d812c61c0e6b5faac4dfafcee4aa3efbc5399a39b555ffdcd9 A /usr/bin/privet [keremet@host-15 ~]$ ``` @@ -38,7 +38,7 @@ sudo ostree trivial-httpd -P 80 repo ``` -На клиенте надо подключить удаленный репозиторий ostree +На клиенте надо подключить удаленный репозиторий ostree. При создании коммита можно указывать --gpg-sign и тогда будет проверка подписи ``` ostree remote add --no-gpg-verify alt http://192.168.2.126 ``` @@ -50,23 +50,19 @@ ostree remote show-url alt ostree remote refs alt ``` -Отображение состояния и обновление. В данном примере показано, что для обновления требуется указывать переменную окружения OSTREE_GRUB2_EXEC, необходимость чего хорошо бы устранить +Отображение состояния и обновление. ``` [root@localhost ~]# ostree admin status -* alt-coreos 4e1b4eb4512bd032b91a3a65c396d853e3a94033e07f75ed2f0faba23b7a77a2.0 +* alt-coreos 6a20a507690294aa2787257a22a3830ee7c19195136924b84ee3fb5de2c6774e.0 origin refspec: alt:alt/x86_64/coreos/stable -[root@localhost ~]# ostree admin upgrade +[root@localhost ~]# ostree admin upgrade 6 metadata, 1 content objects fetched; 20 KiB transferred in 0 seconds; 12 bytes content written Copying /etc changes: 3 modified, 0 removed, 13 added -error: Bootloader write config: Failed to execute child process ?no? (No such file or directory) -[root@localhost ~]# OSTREE_GRUB2_EXEC=/usr/sbin/grub-mkconfig ostree admin upgrade -2 metadata, 0 content objects fetched; 0 bytes content written -Copying /etc changes: 3 modified, 0 removed, 13 added -Transaction complete; bootconfig swap: yes; bootversion: boot.0.0, deployment count change: 1 +Transaction complete; bootconfig swap: yes; bootversion: boot.0.1, deployment count change: 1 [root@localhost ~]# ostree admin status - alt-coreos 0adc3481f84764b4139a2e3ebd6cb351e15d69208e526327e5d3c8fddf1cafd9.1 (pending) + alt-coreos ef1232b040e3f4d812c61c0e6b5faac4dfafcee4aa3efbc5399a39b555ffdcd9.0 (pending) origin refspec: alt:alt/x86_64/coreos/stable -* alt-coreos 4e1b4eb4512bd032b91a3a65c396d853e3a94033e07f75ed2f0faba23b7a77a2.0 +* alt-coreos 6a20a507690294aa2787257a22a3830ee7c19195136924b84ee3fb5de2c6774e.0 origin refspec: alt:alt/x86_64/coreos/stable [root@localhost ~]# ```