开发者社区> 问答> 正文

云服务器 ECS Linux 系统进程关联线程数统计及调整说明是什么



进程关联线程数统计说明



Linux 系统下,可以通过以下三种方式查询应用程序(进程)创建了多少线程(thread)。
  • [url=https://help.aliyun.com/knowledge_detail/41226.html?spm=5176.7841174.2.5.uofVgZ#通过  /proc/$PID/status 进行查看]通过  /proc/$PID/status 进行查看[/url]
  • [url=https://help.aliyun.com/knowledge_detail/41226.html?spm=5176.7841174.2.5.uofVgZ#通过 /proc/$PID/task 目录下的目录数判断线程数量]通过 /proc/$PID/task 目录下的目录数判断线程数量[/url]
  • 通过 ps 命令统计线程


通过  /proc/$PID/status 进行查看


首先,通过 ps 等指令,查询目标进程的进程 ID(PID):
  1. # 以 ssh 进程为例ps -ef | grep sshroot       874     1  0 May31 ?        00:00:01 /usr/sbin/sshd -Droot      3957   874  0 09:59 ?        00:00:00 sshd: root@pts/0root      3993  3959  0 09:59 pts/0    00:00:00 grep —color=auto ssh# 第二列即为相应进程的 PID 号

然后,通过如下指令,结合相应进程的 PID 查询其已创建线程数:
  1. 格式:cat /proc/$PID/status示例:$ cat /proc/874/status | grep ThreadThreads:    1# 说明当前该进程创建的线程数为 1


通过 /proc/$PID/task 目录下的目录数判断线程数量


进程每创建一个线程,系统会在 /proc/$PID/task 目录下创建一个子目录,目录名即为线程 ID。通过统计相应进程对应 task目录下的子目录数量即可统计出线程数量。操作说明如下。
首先,同样的,参阅前述说明,通过 ps 等指令,查询目标进程的进程 ID(PID)。
然后,通过如下指令,结合相应进程的 PID 查询其已创建线程数:
  1. 格式:ls /proc/$PID/task | wc -l示例:$ ls /proc/874/task | wc -l1# 返回的数值即为相应进程创建的线程数。


通过 ps 命令统计线程


通过 ps 指令也可以统计进程关联线程数。说明如下。
首先,同样的,参阅前述说明,通过 ps 等指令,查询目标进程的进程 ID(PID)。
然后,通过如下指令,结合相应进程的 PID 查询其已创建线程数:
  1. 格式:ps hH p $PID | wc -l参数说明:-h 表示不显示标题-H 表示显示进程的层级关系$PID 是相应进程的进程号示例:$ ps hH p 874 | wc -l1# 返回的数值即为相应进程创建的线程数。


Linux 系统无法创建线程错误原因及解决方法


  • 问题描述:业务软件或系统日志中可能出现类似如下日志信息:unable to create new native thread
  • 问题分析:出现该错误,通常是由于系统无法创建更多进程所致。可以使用如下指令查看当前系统最大可创建线程数。
    1. 指令:ulimit -a | grep示例输出:$ ulimit -a | grep processesmax user processes              (-u) 7812# max user processes  右侧的数值即表示当前单用户可创建的最大线程总数
  • 处理办法:根据操作系统的不同,可以参阅该文档修改系统配置文件,调整最大可创建进程数。


如果问题还未能解决,您可以到阿里云社区进行 免费咨询,或联系云市场商家 寻求帮助

展开
收起
boxti 2017-10-23 16:45:34 2201 0
0 条回答
写回答
取消 提交回答
问答排行榜
最热
最新

相关电子书

更多
如何运维千台以上游戏云服务器 立即下载
网站/服务器取证 实践与挑战 立即下载
ECS块储存产品全面解析 立即下载