Linux最大进程数ulimit
docker>Evan2019年9月16日 (一) 06:09的版本 (→** 系统总限制-最终于的解决办法)
目录
* env centos 7
* 查看用户打开的最大进程数
ulimit -a max user processes (-u) 64024 #系统限制某用户下最多可以运行多少进程或线程
这些个值来由
root@dev-hello-1 ~]# cat /proc/sys/kernel/threads-max 128049 root 账号下 ulimit -u 出现的max user processes 的值默认是 # cat /proc/sys/kernel/threads-max的值/2,即系统线程数的一半 普通账号下 ulimit -u 出现的max user processes的值 默认是 /etc/security/limits.d/20-nproc.conf(centos6 是90-nproc.conf) 文件中
* 修改这个值
** /etc/security/limits.conf
echo "* soft nproc 65535" >> /etc/security/limits.conf echo "* hard nproc 65535" >> /etc/security/limits.conf 注意:修改这里,普通用户 max user process值是不生效的,需要修改/etc/security/limits.d/20-nproc.conf文件中的值。 如果使用*号让全局用户生效是受文件/etc/security/limits.d/20-nproc.conf中nproc值大小制约的,而如果仅仅是针对某个用户,那么就不受该文
** /etc/security/limits.d/20-nproc.conf
因为普通用户受这个文件里的值影响 echo "* soft nproc 65535" >> /etc/security/limits.d/20-nproc.conf
** 系统总限制-最终于的解决办法
其实上面的 max user processes 65535 的值也只是表象,普通用户最大进程数无法达到65535 ,因为用户的max user processes的值,最后是受全局的kernel.pid_max的值限制。也就是说kernel.pid_max=1024 ,那么你用户的max user processes的值是127426 ,用户能打开的最大进程数还是1024。 查看全局的pid_max方法: 方法一: cat /proc/sys/kernel/pid_max 方法二: # sysctl kernel.pid_max kernel.pid_max = 32768 最终于的解决办法修改这个值方法: 永久生效方法: 在/etc/sysctl.conf中添加kernel.pid_max = 65535 # vim /etc/sysctl.conf kernel.pid_max = 65535 或者: echo "kernel.pid_max = 65535" >> /etc/sysctl.conf sysctl -p 不行 NOTE: 然后重启机器才能得到 max user processes (-u) 65535