I have a closed source software with some memory leaks problems. Is there a tool or solution to “sandboxe” processes in a fixed amount of memory without using “ulimit” (to generic, I need a per-application memory control)
On systemd-based distros you can also use systemd-run (which indirectly uses cgroups). For example:
systemd-run --scope -p MemoryLimit=1G firefox
Note: this gonna ask you for a password but the app gets launched as your user. Do not allow this to mislead you into thinking that the command needs to run with
sudo, because that would cause the command to run under root, which hardly was your intention.
If you want to not enter the password (indeed, why would you need a password to limit memory you already own), you could use
--user option, however for this to work you gonna need cgroupsv2 support enabled, which right now requires to boot with
systemd.unified_cgroup_hierarchy kernel parameter.
Correct answer by Hi-Angel on August 7, 2020
Use cgroups. https://www.kernel.org/doc/Documentation/cgroups/
Note the difference between
memory.memsw.limit_in_bytes. Also note
Answered by Ken Sharp on August 7, 2020
'ulimit' is a 'per-application' control… per process in fact. The ulimit shell command is a shell built-in setting the limit for the shell process and its children. Put the 'ulimit' command in the script starting your application and the limit will be set for this application only.
Answered by Jacek Konieczny on August 7, 2020
You could use a process management daemon like
monit to monitor the amount of memory in use by your proceses and restart it when it grows over your defined limit.
This does sound drastic, but given your application is known to leak, restarting it regularly based on its usage is just putting off the inevitable, when the process size grows larger than the smaller of, your machines physical memory, or any address space limitations imposed by your operating system.
Answered by Dave Cheney on August 7, 2020
2 Asked on January 5, 2021 by juan-carlos
3 Asked on January 5, 2021 by gnanam
1 Asked on January 4, 2021 by jamiet
2 Asked on January 4, 2021 by user1471465
1 Asked on January 4, 2021 by naveed-mazhar
1 Asked on January 3, 2021 by bountiful
0 Asked on January 3, 2021 by frumpybuttons
2 Asked on January 3, 2021 by dairo
1 Asked on January 3, 2021 by luke-shaheen
1 Asked on January 3, 2021 by mike-metully
1 Asked on January 2, 2021 by nils-eijk
1 Asked on January 2, 2021 by user2018953
1 Asked on January 2, 2021 by anujarosha
1 Asked on January 2, 2021 by nazanin
0 Asked on January 1, 2021 by igniter
Get help from others!