Linux系统入门学习:在 Linux 中统计一个进程的线程数

lonesomer 2015-09-17

问题: 我正在运行一个程序,它在运行时会派生出多个线程。我想知道程序在运行时会有多少线程。在 Linux 中检查进程的线程数最简单的方法是什么?

如果你想看到 Linux 中每个进程的线程数,有以下几种方法可以做到这一点。

 

方法一: /proc

proc 伪文件系统,它驻留在 /proc 目录,这是最简单的方法来查看任何活动进程的线程数。 /proc 目录以可读文本文件形式输出,提供现有进程和系统硬件相关的信息如 CPU、中断、内存、磁盘等等.

  1. <span class="pln">$ </span><span class="kwd">cat</span><span class="pun">/</span><span class="pln">proc</span><span class="pun">/<</span><span class="pln">pid</span><span class="pun">>/</span><span class="pln">status</span>

上面的命令将显示进程 <pid> 的详细信息,包括过程状态(例如, sleeping, running),父进程 PID,UID,GID,使用的文件描述符的数量,以及上下文切换的数量。输出也包括进程创建的总线程数如下所示。

  1. <span class="typ">Threads</span><span class="pun">:</span><span class="pun"><</span><span class="pln">N</span><span class="pun">></span>

例如,检查 PID 20571进程的线程数:

  1. <span class="pln">$ </span><span class="kwd">cat</span><span class="pun">/</span><span class="pln">proc</span><span class="pun">/</span><span class="lit">20571</span><span class="pun">/</span><span class="pln">status</span>

Linux系统入门学习:在 Linux 中统计一个进程的线程数

输出表明该进程有28个线程。

或者,你可以在 /proc//task 中简单的统计子目录的数量,如下所示。

  1. <span class="pln">$ </span><span class="kwd">ls</span><span class="pun">/</span><span class="pln">proc</span><span class="pun">/<</span><span class="pln">pid</span><span class="pun">>/</span><span class="pln">task </span><span class="pun">|</span><span class="kwd">wc</span>

这是因为,对于一个进程中创建的每个线程,在 /proc/<pid>/task 中会创建一个相应的目录,命名为其线程 ID。由此在 /proc/<pid>/task 中目录的总数表示在进程中线程的数目。

 

方法二: ps

如果你是功能强大的 ps 命令的忠实用户,这个命令也可以告诉你一个进程(用“H”选项)的线程数。下面的命令将输出进程的线程数。“h”选项需要放在前面。

  1. <span class="pln">$ </span><span class="kwd">ps</span><span class="pln"> hH p </span><span class="pun"><</span><span class="pln">pid</span><span class="pun">></span><span class="pun">|</span><span class="kwd">wc</span><span class="pun">-</span><span class="pln">l</span>

如果你想监视一个进程的不同线程消耗的硬件资源(CPU & memory),请参阅此教程。


via: http://ask.xmodulo.com/number-of-threads-process-linux.html

作者:Dan Nanni 译者:strugglingyouth 校对:wxy

本文由 LCTT 原创翻译,Linux中国 荣誉推出

相关推荐