Re: Swap on BTRFS

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 2020-11-11 at 01:04 -0700, Chris Murphy wrote:
> On Thu, Nov 5, 2020, 10:03 AM Patrick O'Callaghan <pocallaghan@xxxxxxxxx>
> wrote:
> 
> > The swapon(8) man page says:
> > 
> >    The  swap  file  implementation in the kernel expects to be able to
> > write
> >    to the file directly, without the assistance of the filesystem.  This
> > is a
> >    problem on files with holes or on copy-on-write files on filesystems
> > like Btrfs.
> > 
> > As I'm getting OOM errors when I try to run a VM, it looks like I need
> > a swap file or partition. I'd prefer to use part of my (large) SSD for
> > this, but currently it's entirely formatted as BTRFS. Do I need to
> > resize the BTRFS partition rather than using a swap file?
> 
> 
> 
> 
> There's several options depending on the workload.
> 
> swapfile on Btrfs performs the same as a swap partition in my testing. The
> main difference other than the limitations in 'man 5 btrfs' is an
> additional  set of steps are needed to make it possible to do  hibernation.
> 
> The swapfile must not be snapshot. If it is, COW applies and the swapfile
> can no longer be activated. There's several ways to avoid this if you want
> to snapshot root (but not the swapfile). Create a /swap subvolume, or
> /var/swap subvolume. Since btrfa snapshots are not recursive, either of
> these prevents a snapshot of root from snapshotting the swapfile.
> 
> if you aren't doing any snapshotting at all then it doesn't matter you can
> probably make the swapfile most anywhere.
> 
> I've got some work to do to figure out if there's a more elegant way to do
> it. And of course, encryption and SELinux implications.
> 
> The longer story is to automatically create the swap files on demand
> dynamically in the proper location. And in that case possibly use zswap,
> instead of swap on zram.
> 
> It's a bit esoteric, but there is a way to track sysfs memory.stat for page
> faults. And the zram driver tracks some statistics that could be helpful in
> figuring out situations where zram is getting full of seldom used dirty
> pages that are just taking up memory. In those kinds of workloads it's
> probably more beneficial to use conventional disk-based swap. That's
> because disk space swap fully evicts the page, freeing up all of that
> memory, whereas with the zram based swap we are still consuming some
> memory, in effect it's a partial eviction.
> 
> One thing to watch out for with new installs, it's possible we will see
> cases where there's average or below average RAM and heavy Firefox usage.
> And it could be easier to go below the low water threshold on zram-based
> swap, leading to early home issuing SIGTERM to a Firefox tab. This does get
> logged.
> 
> I think the first recommendation is to create a custom zram-generator
> configuration and bump the size of the zram device from 50% ram to 75% ram.
> While 100% is normally OK, it might be a use case better off with disk
> based swap. It just depends on the workload.
> 
> Most users should be ok with the defaults. It's what I'm using most of the
> time for over one year now. But I'm always on the lookout for any issues.

Thanks. For the moment I'm not doing hibernation (it doesn't work
properly when you have a VM guest with GPU passthrough, basically
because the GPU state is not preserved) but I'll keep your notes on
file if I ever change my mind.

poc
_______________________________________________
users mailing list -- users@xxxxxxxxxxxxxxxxxxxxxxx
To unsubscribe send an email to users-leave@xxxxxxxxxxxxxxxxxxxxxxx
Fedora Code of Conduct: https://docs.fedoraproject.org/en-US/project/code-of-conduct/
List Guidelines: https://fedoraproject.org/wiki/Mailing_list_guidelines
List Archives: https://lists.fedoraproject.org/archives/list/users@xxxxxxxxxxxxxxxxxxxxxxx



[Index of Archives]     [Older Fedora Users]     [Fedora Announce]     [Fedora Package Announce]     [EPEL Announce]     [EPEL Devel]     [Fedora Magazine]     [Fedora Summer Coding]     [Fedora Laptop]     [Fedora Cloud]     [Fedora Advisory Board]     [Fedora Education]     [Fedora Security]     [Fedora Scitech]     [Fedora Robotics]     [Fedora Infrastructure]     [Fedora Websites]     [Anaconda Devel]     [Fedora Devel Java]     [Fedora Desktop]     [Fedora Fonts]     [Fedora Marketing]     [Fedora Management Tools]     [Fedora Mentors]     [Fedora Package Review]     [Fedora R Devel]     [Fedora PHP Devel]     [Kickstart]     [Fedora Music]     [Fedora Packaging]     [Fedora SELinux]     [Fedora Legal]     [Fedora Kernel]     [Fedora OCaml]     [Coolkey]     [Virtualization Tools]     [ET Management Tools]     [Yum Users]     [Yosemite News]     [Gnome Users]     [KDE Users]     [Fedora Art]     [Fedora Docs]     [Fedora Sparc]     [Libvirt Users]     [Fedora ARM]

  Powered by Linux