Linux最大线程数限制及当前线程数查询
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux最大线程数限制及当前线程数查询相关的知识,希望对你有一定的参考价值。
参考技术A 查看系统允许的最大线程数:Linux无法直接控制单个进程可拥有的线程数,但有参考公式max = VM/stack_size,默认stack为8k,可通过降低stack大小或增加虚拟内存来调大每个进程可拥有的最大线程数;
对于支持多线程的程序如Java,有可能会遇到一个进程无法创建更多线程的情形,其原因多种多样,而OS端可能由此参数造成.
查看系统允许的最大进程数:
ulimit -a 显示当前所有的资源限制
root用户下执行 ulimit -a 然后查看 max user processes 这个值通常是系统最大线程数的一半:/proc/sys/kernel/threads-max/2
普通用户下 ulimit -u 出现的max user processes的值 默认是 /etc/security/limits.d/20-nproc.conf(centos6 是90-nproc.conf) 文件中的
普通用户默认是1024
打开/etc/security/limits.conf (部分的系统是在/etc/security/limits.d/90-nproc.conf)
设置限制数量,第一列表示用户,* 表示所有用户
soft nproc :单个用户可用的最大进程数量(超过会警告);
hard nproc:单个用户可用的最大进程数量(超过会报错);
soft nofile :可打开的文件描述符的最大数(超过会警告);
hard nofile :可打开的文件描述符的最大数(超过会报错);
重启后生效
reboot
查询当前某程序的线程数
pstree -p 进程号 | wc -l
管道符号"|"左边命令的输出作为右边命令的输入
直接修改/etc/security/limits.conf 文件中的 * soft nproc 65535 值后,普通用户最大进程数无法达到65535 ,因为用户的max user processes的值,最后是受全局的kernel.pid_max的值限制。也就是说kernel.pid_max=1024 ,那么你用户的max user processes的值是127426 ,用户能打开的最大进程数还是1024。
永久修改系统最高进程数的方法
在/etc/sysctl.conf中添加kernel.pid_max = 65535
vim /etc/sysctl.conf
kernel.pid_max = 65535
或者:
echo "kernel.pid_max = 65535" >> /etc/sysctl.conf
然后重启机器。
临时修改的方法:
echo 65535 > /proc/sys/kernel/pid_max
所以以上都操作完成后,才算是正确修改了max user processes 的值
linux线程数限制与zabbix监控
Linux最大线程数限制及当前线程数查询
最大线程数计算方式:
n = total_memory/128k;
Linux用户线程数限制而导致的程序异常为 java.lang.OutOfMemoryError:unable to create new native thread
查询系统支持的最大进程数与线程数,一般会很大,相当于理论值
/proc/sys/kernel/pid_max
/proc/sys/kernel/threads-max
系统限制某用户下最多可以运行多少进程或线程
当前用户可用最大线程数:ulimit -u
想要修改这个值:
centos 6.*可以修改/etc/security/limits.d/90-nproc.conf
centos 7.*可以修改/etc/security/limits.d/20-nproc.conf
查询当前某程序的线程或进程数
# pstree -p `ps -e | grep java | awk \'{print $1}\'` | wc -l
# pstree -p 进程号 | wc -l
上面用的是管道,关于管道:管道符号"|"左边命令的输出作为右边命令的输入
查询当前整个系统已用的线程或进程数
pstree -p | wc -l
以上参考https://www.cnblogs.com/nizuimeiabc1/p/5593637.html
zabbix监控当前使用线程数
客户端:使用pstree -p | wc -l为键值
pstree以树结构显示进程,是linux很有用的一个命令,可打印系统当前各个进程父子关系。但是centos7默认并没有安装pstree,所以会有pstree:command not found
实际上在linux平台要安装psmisc包,安装方式使用命令即可:yum install psmisc -y
增加自定义监控项的键值:echo "UserParameter=thread.num,pstree -p | wc -l" >> /etc/zabbix/zabbix_agentd.conf
然后重启zabbix_agentd客户端
服务端:在Template OS Linux模板中添加监控项与触发器,阀值8000
测试,服务端get一下数据,看能不能拿到
/usr/local/zabbix/bin/zabbix_get -s xxx.xxx.xxx.xxx -p 10050 -k \'thread.num\'
把阀值临时设为200,看能不能接到告警邮件
以上是关于Linux最大线程数限制及当前线程数查询的主要内容,如果未能解决你的问题,请参考以下文章