How can I limit the CPU and RAM usage for a process?
Solution 1:
Be warned: Here there be dragons.
When you start going down the path of specifically controlling resources of applications / processes / threads to this extent, you begin to open a literal Pandora's box of problems when it comes time to debug an issue that your rate limiting did not take into account.
That said, if you believe that you know what you're doing, there are three options available to you: nice
, cpulimit
, and control groups (Cgroups).
Here is a TL;DR for these three methods:
Nice ⇢ nice {process}
This is a very simple way to prioritise a task and is quite effective for "one off" uses, such as reducing the priority of a long-running, computationally-expensive task that should use more of the CPU when the machine is not being used by other tasks (or people).
CPU Limit ⇢ cpulimit -l 60 {process}
If your server performance suffers (a.k.a. stalls) when the CPU usage exceeds a certain amount, then cpulimit
can help reduce the pressure on the system. It does this by pausing the process at different intervals to keep it under a defined ceiling by sending SIGSTOP
and SIGCONT
signals to the process. cpulimit
does not change the nice
value of the process, instead it monitors and controls the real-world CPU usage.
You will find that cpulimit
is useful when you want to ensure that a process doesn't use more than a certain portion of the CPU, which your question alludes to, but a disadvantage is that the process cannot use all of the available CPU time when the system is idle (which nice
allows).
CGroups
sudo cgcreate -g cpu:/restrained
sudo cgset -r cpu.shares=768 restrained
sudo cgexec -g cpu: restrained {process}
Cgroups — control groups — are a feature built into the Linux kernel that enables you to control how resources should be allocated. With Cgroups you can specify how much CPU, memory, bandwidth, or combinations of these resources can be used by the processes that are assigned to a group.
A key advantage of Cgroups over nice
or cpulimit
is that the limits are applied to a set of processes; not just one. nice
and cpulimit
are also limited to restricting the CPU usage of a process, whereas Cgroups can limit other process resources.
If you go down the rabbit-hole of Cgroups then you can hyper-optimise a system for a specific set of tasks.
Solution 2:
A heads up: if you don't want to give the process a hard limit, just a priority, look up the
nice
command. This answer will assume you want a hard limit.
Limiting CPU Usage
This wonderful answer to a different question explains it pretty well
Install cpulimit
sudo apt-get install cpulimit
It provides different methods of limiting the CPU usage of a process
foo
to say, 20%
By its process-name:
sudo cpulimit -e foo -l 20
.By its absolute path name:
sudo cpulimit -P /usr/bin/foo -l 20
By its PID:
- Find the PID of the process:
pidof foo
. (say, it outputs 1881)sudo cpulimit -p 1881 -l 20
Limiting Memory Usage
For more options, see this post on how to limit RAM usage.
For example, to limit process 12345 to 2048 MB of RAM usage, you could use the prlimit
command
$ prlimit --pid 12345 --as=2048000000