Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Backport overlayfs creation approach from v19 #13

Merged
merged 8 commits into from
May 20, 2024

Conversation

Monstrofil
Copy link
Collaborator

This pull request backports new approach of overlayfs creation made in upstream leapp v19.

Basically, before these changes size of the virtual fs was determited by LEAPP_OVL_SIZE environment variable and was not dynamically changed accoring to real usage which lead to disk space problems during upgrade.

New solution has better support for ftype=0 mounts and also better space estimation.

You can find details in commit message.

pirat89 and others added 7 commits May 14, 2024 14:01
We are going to redesign the use of overlay images during the upgrade
to resolve number of issues we have with the old solution. However,
we need to keep the old solution as a fallback (read below). This
is small preparation to keep the new and old code separated safely.

Reasoning for the fallback:
* There is a chance the new solution could raise also some problems
mainly for systems with many partitions/volumes in fstab, or when
they are using many loop devices already - as the new solution will
require to create loop device for each partition/volume noted in
the fstab.
* Also RHEL 7 is going to switch to ELS on Jun 2024 after which the
project will be fixing just critical bugfixes for in-place upgrades.
This problem blocking the upgrade is not considered to be critical.

(cherry picked from commit e4fa867)
All LEAPP_* envars are supposed to be read by library function
which ensures persistent behaviour during the whole upgrade process.

(cherry picked from commit dfd1093)
The in-place upgrade itself requires to do some changes on the system to be
able to perform the in-place upgrade itself - or even to be able to evaluate
if the system is possible to upgrade. However, we do not want to (and must not)
change the original system until we pass beyond the point of not return.

For that purposes we have to create a layer above the real host file system,
where we can safely perform all operations without affecting the system
setup, rpm database, etc. Currently overlay (OVL) technology showed it is
capable to handle our requirements good enough - with some limitations.

However, the original design we used to compose overlay layer above
the host system had number of problems:
    * buggy calculation of the required free space for the upgrade RPM
      transaction
    * consumed too much space to handle partitions formatted with XFS
      without ftype attributes (even tens GBs)
    * bad UX as people had to manually adjust size of OVL disk images
    * .. and couple of additional issues derivated from problems
      listed above

The new solution prepares a disk image (represented by sparse-file)
and an overlay image for each mountpoint configured in /etc/fstab,
excluding those with FS types noted in the `OVERLAY_DO_NOT_MOUNT`
set. Such prepared OVL images are then composed together to reflect
the real host filesystem. In the end everything is cleaned.

The composition could look like this:
  orig mountpoint -> disk img -> overlay img -> new mountpoint
  -------------------------------------------------------------
    /        -> root_        -> root_/ovl        -> root_/ovl/
    /boot    -> root_boot    -> root_boot/ovl    -> root_/ovl/boot
    /var     -> root_var     -> root_var/ovl     -> root_/ovl/var
    /var/lib -> root_var_lib -> root_var_lib/ovl -> root_/ovl/var/lib
    ...

The new solution can be now problematic for system with too many partitions
and loop devices, as each disk image is loop mounted (that's same as
before, but number of disk images will be bigger in total number).
For such systems we keep for now the possibility of the fallback
to an old solution, which has number of issues mentioned above,
but it's a trade of. To fallback to the old solution, set envar:
    LEAPP_OVL_LEGACY=1

Disk images created for OVL are formatted with XFS by default. In case of
problems, it's possible to switch to Ext4 FS using:
    LEAPP_OVL_IMG_FS_EXT4=1
XFS is better optimized for our use cases (faster initialisation
consuming less space). However we have reported several issues related
to overlay images, that happened so far only on XFS filesystems.
We are not sure about root causes, but having the possibility
to switch to Ext4 seems to be wise. In case of issues, we can simple
ask users to try the switch and see if the problem is fixed or still
present.

Some additional technical details about other changes
* Added simple/naive checks whether the system has enough space on
  the partition hosting /var/lib/leapp (usually /var). Consuming the
  all space on the partition could lead to unwanted behaviour
  - in the worst case if we speak about /var partition it could mean
    problems also for other applications running on the system
* In case the container is larger than the expected min default or
  the calculation of the required free space is lower than the
  minimal protected size, return the protected size constant
  (200 MiB).

* Work just with mountpoints (paths) in the _prepare_required_mounts()
instead of with list of MountPoint named tuple. I think about the
removal of the named tuple, but let's keep it for now.

* Make apparent size of created disk images 5% smaller to protect
  failed upgrades during the transaction execution due to really
  small amount of free space.

* Cleanup the scratch directory at the end to free the consumed
  space. Disks are kept after the run of leapp when
      LEAPP_DEVEL_KEEP_DISK_IMGS=1

(cherry picked from commit d074926)
   mknod(/var/lib/leapp/scratch/mounts/root_/system_overlay/dev/null) failed: File exists

Ignoring such vfstype fixes the issue rhbz#2215027

(cherry picked from commit 6e470f4)
In case the filesystem for which the disk img is going to be created
has very small amount of free space (under 130 MiBs), it cannot be
formatted by XFS with current params.

This could be hit in several cases:
 * the system partition/volume - in this case, most likely an issue
   will be hit anyway later by DNF speaking about small amount of
   free space if a content is installed inside by RPMs
   as such a small amount of free space is really not expected
   to see at all
 * it's a data mount point (e.g. iso) or a filesystem type that should
   by part of the OVERLAY_DO_NOT_MOUNT set, so enlarging the value
   to 130 MiBs should not affect anything negatively at all
 * in case of /boot, the problem with the free space is covered
   already in a different actor prior we try to create any disk img,
   so we are safe here

Based on arguments above, I am considering setting the 130 MiBs as
minimal value safe for in-place upgrades. Also it will allow to skip
possible problems with specific file systems (like tmpfs, ...) in case
we are still missing some in the OVERLAY_DO_NOT_MOUNT - and kind of
read only storage (such as iso9660, etc..).

Co-authored-by: Michal Hečko <michal.sk.com@gmail.com>
(cherry picked from commit a81ebb0)
Copy link

Thank you for contributing to the Leapp project!

Please note that every PR needs to comply with the Leapp Guidelines and must pass all tests in order to be mergable.
If you want to re-run tests or request review, you can use following commands as a comment:

  • leapp-ci build to run copr build and e2e tests in OAMG CI
  • review please to notify leapp developers of review request

Please open ticket in case you experience technical problem with the CI. (RH internal only)

Note: In case there are problems with tests not being triggered automatically on new PR/commit or pending for a long time, please consider rerunning the CI by commenting leapp-ci build (might require several comments). If the problem persists, contact leapp-infra.

@Monstrofil
Copy link
Collaborator Author

leapp-ci build

@prilr
Copy link
Collaborator

prilr commented May 16, 2024

@Monstrofil I believe that automation is disabled in our fork.

@prilr prilr merged commit a04faa5 into cloudlinux May 20, 2024
@prilr prilr deleted the clos-2631-backport-xfs-fixes branch June 17, 2024 11:12
prilr pushed a commit that referenced this pull request Aug 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants