开发者社区> 问答> 正文

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

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

展开
收起
开发者说 2019-07-19 18:55:55 1445 0
1 条回答
写回答
取消 提交回答
  • 进程关联线程数统计说明

    Linux 系统下,可以通过以下三种方式查询应用程序(进程)创建了多少线程(thread)。

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

    通过 /proc/$PID/task 目录下的目录数判断线程数量 通过 ps 命令统计线程 通过 /proc/$PID/status 进行查看 首先,通过 ps 等指令,查询目标进程的进程 ID(PID):

    # 以 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 查询其已创建线程数:
    格式:cat /proc/$PID/status
    示例:
    $ cat /proc/874/status | grep 
    ThreadThreads:    1
    # 说明当前该进程创建的线程数为 1
    
    

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

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

    ls /proc/$PID/task | wc -l
    
    

    示例:

    $ ls /proc/874/task | wc -l
    
    
    # 返回的数值即为相应进程创建的线程数。
    
    

    通过 ps 命令统计线程tgps

    通过 ps 指令也可以统计进程关联线程数。说明如下。 首先,同样的,参阅前述说明,通过 ps 等指令,查询目标进程的进程 ID(PID)。 然后,通过如下指令,结合相应进程的 PID 查询其已创建线程数: 格式:

    ```js
    ps hH p $PID | wc -l
    参数说明:
    -h 表示不显示标题
    -H 表示显示进程的层级关系
    $PID 是相应进程的进程号
    
    
    
    示例:
    ```js
    $ ps hH p 874 | wc -l
    
    
    # 返回的数值即为相应进程创建的线程数。
    
    

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

    问题描述: 业务软件或系统日志中可能出现类似如下日志信息: ```js unable to create new native thread

    问题分析: 出现该错误,通常是由于系统无法创建更多进程所致。可以使用如下指令查看当前系统最大可创建线程数。
    ```js
    指令:
    ulimit -a | grep
    示例输出:
    $ ulimit -a | grep 
    processesmax user processes (-u) 7812# max user processes
    

    右侧的数值即表示当前单用户可创建的最大线程总数 处理办法: 根据操作系统的不同,可以参阅该文档修改系统配置文件,调整最大可创建进程数。

    2019-07-26 21:23:45
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
如何运维千台以上游戏云服务器 立即下载
网站/服务器取证 实践与挑战 立即下载
ECS快储存加密技术 立即下载