From 6890dfe5ca5ad641e356359c09a0f6265420f428 Mon Sep 17 00:00:00 2001 From: Michael Hudson-Doyle Date: Wed, 23 Aug 2023 11:16:23 +1200 Subject: [PATCH] Deduplicate the layers just before creating the squashfs, to enable deduplication of the result of binary hooks as well. --- debian/changelog | 7 +++++++ live-build/lb_binary_layered | 18 +++++++++++++++++- live-build/lb_chroot_layered | 19 ++++--------------- 3 files changed, 28 insertions(+), 16 deletions(-) diff --git a/debian/changelog b/debian/changelog index 025befe2..4c1d50aa 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,3 +1,10 @@ +livecd-rootfs (23.10.21) UNRELEASED; urgency=medium + + * Deduplicate the layers just before creating the squashfs, to enable + deduplication of the result of binary hooks as well. + + -- Michael Hudson-Doyle Wed, 23 Aug 2023 11:15:26 +1200 + livecd-rootfs (23.10.20) mantic; urgency=medium * Update canary model assertions to include all the regular seeded snaps, diff --git a/live-build/lb_binary_layered b/live-build/lb_binary_layered index 146978d3..1fb33af9 100755 --- a/live-build/lb_binary_layered +++ b/live-build/lb_binary_layered @@ -142,7 +142,23 @@ build_layered_squashfs () { cp "${squashfs_f_manifest}.full" "${prefix}.manifest" fi - create_squashfs "overlay.${pass}/" ${squashfs_f} + if [ -n "$lowerdirs" ]; then + # Although the current chroot was created as an overlay over + # the previous layer, many operations can result in redundant + # files in the upperdir. Rather than trying to minimize the + # overlay by hand, we rsync the chroot into a fresh overlay, + # rely on rsyncs ability to avoid redundant file operations, + # and take _that_ overlay's upperdir as the content of the + # layer. + mkdir -p chroot-2 "$overlay_dir-2" + mount_overlay "$lowerdirs" "$overlay_dir-2" chroot-2 + rsync -caXHAS --no-t --del chroot/ chroot-2/ + umount chroot-2 + rmdir chroot-2 + overlay_dir="$overlay_dir-2" + fi + + create_squashfs "${overlay_dir}" ${squashfs_f} if [ -f config/$pass.catalog-in.yaml ]; then echo "Expanding catalog entry template for $pass" diff --git a/live-build/lb_chroot_layered b/live-build/lb_chroot_layered index d3173755..eb55131f 100755 --- a/live-build/lb_chroot_layered +++ b/live-build/lb_chroot_layered @@ -131,8 +131,8 @@ create_chroot_pass () { mkdir -p "$overlay_dir/" lowerdirs=$(get_lowerdirs_for_pass $pass) if [ -n "$lowerdirs" ]; then - mkdir -p chroot "${overlay_dir}-initial" - mount_overlay "$lowerdirs" "${overlay_dir}-initial" chroot/ + mkdir -p chroot/ + mount_overlay "$lowerdirs" "$overlay_dir" chroot/ else ln -s "$overlay_dir/" chroot fi @@ -268,19 +268,8 @@ create_chroot_pass () { lb chroot_devpts remove ${*} if [ -n "$lowerdirs" ]; then - # Although the current chroot was created as an overlay over - # the previous layer, many operations can result in redundant - # files in the upperdir. Rather than trying to minimize the - # overlay by hand, we rsync the chroot into a fresh overlay, - # rely on rsyncs ability to avoid redundant file operations, - # and take _that_ overlay's upperdir as the content of the - # layer. - mkdir chroot-2 - mount_overlay "$lowerdirs" "$overlay_dir" chroot-2/ - rsync -aXHAS --del chroot/ chroot-2/ - umount chroot chroot-2 - rmdir chroot chroot-2 - rm -rf ${overlay_dir}-initial + umount chroot + rmdir chroot else rm chroot fi