Linux下的一些资源限制
前言
用户层面资源限制
-----------------------------------------------------
该文件为通过PAM登录的用户设置资源限制。
它不会影响系统服务的资源限制。
-----------------------------------------------------
所以 ulimit 的确是观察用户层面的资源限制。
我们可以通过 ulimit -a 查看我们所有的资源上限:
只说其中我们比较关注的那些:
-s 栈大小:8MB
-u 进程上限:30000多
-n 文件描述符上限:1024
实验1. 修改文件描述符上限
在/etc/security/limits.conf中添加以下片段:
重启后,然后查看一下资源是否真的被修改了:
接着我们看一下结果:
实验2. 修改栈空间上限
同样还是在/etc/security/limits.conf添加这样两句:
然后在c程序中测试栈帧的上限:
程序正常。将栈调到临界值:
程序发生段错误。
系统层面资源限制
单个进程打开文件句柄数上限 最大文件描述符数 10亿。
系统分配的pid上限是400多万。
file-max是在内核级别强制执行的最大文件描述符(FD),上限600万。
已分配的文件文件描述符数,已分配但未使用的文件描述符数以及最大文件描述符数(不可调)。
系统全局的总线程数限制为6万。
单个程序所能使用内存映射空间的数量为6万。
可以创建的线程的总数和这些有关:
一个进程的资源限制
redis中文件描述符上限的调整
Increased maximum number of open files to 10032 (it was originally set to 1024).
其源码中也不过是调用了api:
setrlimit(RLIMIT_NOFILE,&limit)
去进行了资源上限的临时调整,此处不细讲。
prlimit
最后介绍另外一个类似ulimit的命令prlimit:
结语