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最大线程数限制及当前线程数查询的主要内容,如果未能解决你的问题,请参考以下文章

linux 最多支持多少个线程

linux下查看线程数的方法及超过系统线程最大值的报错

修改linux系统用户最大线程数限制

最大线程数 Windows Threads limit

Linux最大线程数限制

linux线程数怎么看