在SMP系统中,我们的应用程序经常使用多线程的技术,那么在Linux中如何查看某个进程的多个线程呢?
本文介绍3种命令来查看Linux系统中的线程(LWP)的情况:
在我的系统中,用qemu-system-x86_64命令启动了一个SMP的Guest,所以有几个qemu的线程,以此为例来说明。
1. pstree 命令
查看进程和线程的树形结构关系
[root@jay-linux~]#pstree|grepqemu
|-terminal-+-bash---qemu-sys---2*[{qemu-system-x8}]
[root@jay-linux~]#pstree-p|grepqemu
|-terminal(194)-+-bash(196)---qemu-sys(657)-+-{qemu}(660)
||`-{qemu}(661)
2. ps 命令
-L参数显示进程,并尽量显示其LWP(线程ID)和NLWP(线程的个数)。
[root@jay-linux~]#ps-eLf|grepqemu
root6571966570313:48pts/100:00:00qemu-sys-m1024-smp2
root6571966603313:48pts/100:00:26qemu-sys-m1024-smp2
root6571966612313:48pts/100:00:19qemu-sys-m1024-smp2
root7899799107890114:02pts/000:00:00grep--color=autoqemu
上面命令查询结果的第二列为PID,第三列为PPID,第四列为LWP,第六列为NLWP。
另外,ps命令还可以查看线程在哪个CPU上运行,命令如下:
[root@jay-linux~]#ps-eoruser,pid,ppid,lwp,psr,args-L|grepqemu
root6571966571qemu-sys-hdasmep-temp.qcow-m1024-smp2
root6571966601qemu-sys-hdasmep-temp.qcow-m1024-smp2
root6571966612qemu-sys-hdasmep-temp.qcow-m1024-smp2
root8349799108341grep--color=autoqemu
其中,每一列依次为:用户ID,进程ID,父进程ID,线程ID,运行该线程的CPU的序号,命令行参数(包括命令本身)。
3. top 命令
其中H命令可以显示各个线程的情况。(在top命令后,按H键;或者top -H)
[root@jay-linux~]#top-H
top-14:18:20up22:32,4users,loadaverage:2.00,1.99,1.90
Tasks:286total,1running,285sleeping,0stopped,0zombie
Cpu(s):0.0%us,0.0%sy,0.0%ni,100.0%id,0.0%wa,0.0%hi,0.0%si,0.0%st
Mem:3943892ktotal,1541540kused,2402352kfree,164404kbuffers
Swap:4194300ktotal,0kused,4194300kfree,787768kcached
PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND
660root2001313m188m2752S2.34.90:46.78qemu-sys
661root2001313m188m2752S2.04.90:39.44qemu-sys
867root200152601312960R0.30.00:00.07top
1root2001944415601252S0.00.00:00.34init
2root200000S0.00.00:00.02kthreadd
....
在top中也可以查看进程(进程)在哪个CPU上执行的。
执行top后,按f,按j(选中* J: P = Last used cpu (SMP)),然后按空格或回车退出设置,在top的显示中会多出P这一列是最近一次运行该线程(进程)的CPU。
PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+PCOMMAND
661root2001313m188m2752S2.34.90:44.243qemu-sys
660root2001313m188m2752S2.04.90:51.740qemu-sys
874root200152601284860R0.70.00:00.322top
1root2001944415601252S0.00.00:00.340init
2root200000S0.00.00:00.021kthreadd