diff options
| author | Philip J Freeman <elektron@halo.nu> | 2025-05-31 12:34:14 -0700 |
|---|---|---|
| committer | Philip J Freeman <elektron@halo.nu> | 2025-05-31 15:47:31 -0700 |
| commit | 34105077c777b0d2c5c69f39921f376b84ce1443 (patch) | |
| tree | 606152d6f739a0ee7fd8e5127e79b595f3fe8c85 /hooks/build-os-post | |
| parent | 5392080129b1093f36533e47c155f618c283ea57 (diff) | |
Deploying a demo amd64 debian-based OS via ostree
This is a prototype outline for building and deploying a debian based OS
with ostree. For purposes of demonstration, the OS runs from a bootable
USB device on a UEFI capable amd64 machine. Once a USB device is
created and booted, the OS can be updated using a simple shell script.
<https://ostreedev.github.io/ostree/>
<https://www.nin.wiki/Halo_numbers>
Diffstat (limited to 'hooks/build-os-post')
| -rwxr-xr-x | hooks/build-os-post/20-ostree-kernel-mangle | 22 | ||||
| -rwxr-xr-x | hooks/build-os-post/40-ostree-demo-scripts | 36 | ||||
| -rwxr-xr-x | hooks/build-os-post/90-ostree-path-mangles | 47 |
3 files changed, 105 insertions, 0 deletions
diff --git a/hooks/build-os-post/20-ostree-kernel-mangle b/hooks/build-os-post/20-ostree-kernel-mangle new file mode 100755 index 0000000..1e51905 --- /dev/null +++ b/hooks/build-os-post/20-ostree-kernel-mangle @@ -0,0 +1,22 @@ +#!/bin/bash -xe +set -o pipefail + +# Kernel mangling + +kver=$(ls -1 "${root:?}"/usr/lib/modules) + +# move kernel out of /boot into /usr/lib/modules/ +mv "${root:?}"/boot/vmlinuz-"$kver" "${root:?}"/usr/lib/modules/"$kver"/vmlinuz +mv "${root:?}"/boot/initrd.img-"$kver" "${root:?}"/usr/lib/modules/"$kver"/initramfs.img +mv "${root:?}"/boot/config-"$kver" "${root:?}"/usr/lib/modules/"$kver"/config +mv "${root:?}"/boot/System.map-"$kver" "${root:?}"/usr/lib/modules/"$kver"/System.map + +# remove kernel symlinks from root +rm "${root:?}"/vmlinuz* "${root:?}"/initrd.* + +khash=$(sha256sum "${root:?}"/usr/lib/modules/"$kver"/vmlinuz | awk '{print $1}') + +# add ostree style kernel links from /usr/lib/ostree-boot +mkdir -p "${root:?}"/usr/lib/ostree-boot +ln -s /usr/lib/modules/"$kver"/vmlinuz "${root:?}"/usr/lib/ostree-boot/vmlinuz-"$khash" +ln -s /usr/lib/modules/"$kver"/initramfs.img "${root:?}"/usr/lib/ostree-boot/initramfs-"$khash" diff --git a/hooks/build-os-post/40-ostree-demo-scripts b/hooks/build-os-post/40-ostree-demo-scripts new file mode 100755 index 0000000..6ea5627 --- /dev/null +++ b/hooks/build-os-post/40-ostree-demo-scripts @@ -0,0 +1,36 @@ +#!/bin/bash -xe + +set -o pipefail + +cat > "${root:?}"/usr/sbin/halo-upgrade << EOF +#!/bin/bash -e + +set -o pipefail + +remote="${remote:?}" +branch="${branch:?}" + +remote_ref=\$(ostree remote refs -r "\$remote" | egrep ^"\$remote":"\$branch"'\\s' | awk '{print \$2}') +local_ref=\$(ostree refs -r | egrep ^"\$remote":"\$branch"'\\s' | awk '{print \$2}') + +if [ "\$local_ref" != "\$remote_ref" -a -n "\$remote_ref" ]; then + echo "OS Update available. Installing..." + + set -x + + ostree admin upgrade + + grub-mkconfig -o /boot/grub/grub.cfg + + set +x + + echo "OS Update Installed. Press Enter to Reboot..." + + read + + reboot +else + echo "No OS Update found." +fi +EOF +chmod 755 "${root:?}"/usr/sbin/halo-upgrade diff --git a/hooks/build-os-post/90-ostree-path-mangles b/hooks/build-os-post/90-ostree-path-mangles new file mode 100755 index 0000000..b2709f3 --- /dev/null +++ b/hooks/build-os-post/90-ostree-path-mangles @@ -0,0 +1,47 @@ +#!/bin/bash -xe +set -o pipefail + +# remove everything from dev and var +rm -rf "${root:?}"/dev/* "${root:?}"/var/* + +# add sysroot mountpoint and ostree link to root +mkdir -p "${root:?}"/sysroot +ln -s /sysroot/ostree "${root:?}"/ostree + +# add tmpfiles config to create expected directory structure +cat > "${root:?}"/etc/tmpfiles.d/var.conf << EOF +d /var/log/journal 0755 root root - +L /var/home - - - - ../sysroot/home +d /var/opt 0755 root root - +d /var/srv 0755 root root - +d /var/roothome 0700 root root - +d /var/usrlocal 0755 root root - +d /var/usrlocal/bin 0755 root root - +d /var/usrlocal/etc 0755 root root - +d /var/usrlocal/games 0755 root root - +d /var/usrlocal/include 0755 root root - +d /var/usrlocal/lib 0755 root root - +d /var/usrlocal/man 0755 root root - +d /var/usrlocal/sbin 0755 root root - +d /var/usrlocal/share 0755 root root - +d /var/usrlocal/src 0755 root root - +d /var/mnt 0755 root root - +d /run/media 0755 root root - +d /var/games 0755 root root - +EOF + +# move /etc to /usr/etc +mv "${root:?}"/etc "${root:?}"/usr/etc +mkdir "${root:?}"/etc # do we need this? + +# link persistent directories to /var +for dir in home opt srv mnt tmp; do + rmdir "${root:?}"/"$dir" + ln -s /var/"$dir" "${root:?}"/"$dir" +done + +rm -rf "${root:?}"/root +ln -s /var/roothome "${root:?}"/root + +rm -rf "${root:?}"/usr/local +ln -s /var/usrlocal "${root:?}"/usr/local |
