本文介绍如何限制进程资源。

SysV init

以前我们用的是init启动。如果要限制进程资源,可以修改/etc/security/limits.conf文件。

但是呢,我们systemd不吃这个一套。

systemd

在systemd中,如果要限制资源,需要修改/etc/systemd/system.conf/etc/systemd/system.conf文件。

注意事项,修改/etc/systemd/system.conf后,需要执行systemctl daemon-reexec命令来重新加载配置。

各参数含义

虽然他们读取的配置不会,还存在很多的差异,但是都是使用方式的差异。它们底层控制的资源还是相同的。

下面只是一个概览(有关详细内容及微妙例外情况,强烈建议参考setrlimit(2)手册):

Directive in systemd Unit in systemd ulimit equivalent Description
LimitCPU= ulimit -t Seconds  
LimitCPU= ulimit -t Seconds  
LimitFSIZE= ulimit -f Bytes  
LimitDATA= ulimit -d Bytes  
LimitSTACK= ulimit -s Bytes  
LimitCORE= ulimit -c Bytes  
LimitRSS= ulimit -m Bytes  
LimitNOFILE= ulimit -n Number of File Descriptors 文件描述符的个数
LimitAS= ulimit -v Bytes  
LimitNPROC= ulimit -u Number of Processes 当前用户允许创建的进程数。如果超过或等于该值,在fork(2)时会失败。
LimitMEMLOCK= ulimit -l Bytes  
LimitLOCKS= ulimit -x Number of Locks  
LimitSIGPENDING= ulimit -i Number of Queued Signals  
LimitMSGQUEUE= ulimit -q Bytes  
LimitNICE= ulimit -e Nice Level  
LimitRTPRIO= ulimit -r Realtime Priority  
LimitRTTIME= No equivalent Microseconds  

如何查看指定服务的限制?

我没有找到特定的命令,但是有一个从操作系统中查看的方法:cat /proc/<PID>/limits

其他内容

系统最大支持的进程数可以通过sysctl kernel.pid_max或者通过cat /proc/sys/kernel/pid_max命令查看。如果要修改,通过配置/etc/sysctl.conf配置文件即可。这又是另外一个话题了。

 

 

参考文献

Systemd services and resource limits
Systemd/systemd.exec
How to Set Limits on User Running Processes in Linux
Maximum number of processes in linux
Setting limits with ulimit