-
Notifications
You must be signed in to change notification settings - Fork 52
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
Swap device is created with unexpected size when VM balloon is used #177
Comments
Tempted to say "works as expected", right? When the system has 2G of MemTotal attached |
I don't think it can be considered to "work". First of all, the size is subject to a race condition on every boot. Second, I don't think it's useful to scale to Maximum, because for most VMs that is not relevant, and could possibly be many times higher than Current. You end up with a swap device that is too large for the amount of available RAM; there is no way that 8GB zram device can be filled with 2GB RAM available. (E.g. I can imagine a VM host with 256GB of RAM that is used for a hundred VMs, each configured by default with Current/Maximum of 2/32, just in case a VM needs to be dynamically scaled at some later point…) |
My situation is somewhat similar. I'm using virtio-mem. The system boots with 1G of ram and once the I suppose this is works as intended but it would be nice-to-have if zram-generator detects memory hot-plugging automatically. Since this changes current behavior maybe it could be hidden behind a config option. |
I've come up with two possible solutions.
|
Related to #197. Actually, this issue is exactly what I was experiencing, though under Xen and not QEMU/KVM. |
I have a VM with a large Maximum allocation of 8 GB and Current allocation of 2 GB.
It seems that during boot, the ballooning process is so slow, that
[email protected]
is executed early enough to see the "wrong" size. If I restart the unit later on, zram0 is recreated with the expected size (==RAM).I can't find a reference, but I'm pretty sure we had an issue about this previously when the zram0 device was created directly in the generator. Later on, when we switched to creating of the zram0 device in the unit, this problem "went away", because this step happens a bit later. But it seems that something changed, and the service now runs earlier.
This is ugly… I don't see any source of information about
virtio_balloon
state from within the machine.The text was updated successfully, but these errors were encountered: