在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|grepqemuroot6571966570313:48pts/100:00:00qemu-sys-m1024-smp2root6571966603313:48pts/100:00:26qemu-sys-m1024-smp2root6571966612313:48pts/100:00:19qemu-sys-m1024-smp2root7899799107890114:02pts/000:00:00grep--color=autoqemu
上面命令查询结果的第二列为PID,第三列为PPID,第四列为LWP,第六列为NLWP。
另外,ps命令还可以查看线程在哪个CPU上运行,命令如下:
[root@jay-linux~]#ps-eoruser,pid,ppid,lwp,psr,args-L|grepqemuroot6571966571qemu-sys-hdasmep-temp.qcow-m1024-smp2root6571966601qemu-sys-hdasmep-temp.qcow-m1024-smp2root6571966612qemu-sys-hdasmep-temp.qcow-m1024-smp2root8349799108341grep--color=autoqemu
其中,每一列依次为:用户ID,进程ID,父进程ID,线程ID,运行该线程的CPU的序号,命令行参数(包括命令本身)。
3. top 命令
其中H命令可以显示各个线程的情况。(在top命令后,按H键;或者top -H)
[root@jay-linux~]#top-Htop-14:18:20up22:32,4users,loadaverage:2.00,1.99,1.90Tasks:286total,1running,285sleeping,0stopped,0zombieCpu(s):0.0%us,0.0%sy,0.0%ni,100.0%id,0.0%wa,0.0%hi,0.0%si,0.0%stMem:3943892ktotal,1541540kused,2402352kfree,164404kbuffersSwap:4194300ktotal,0kused,4194300kfree,787768kcachedPIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND660root2001313m188m2752S2.34.90:46.78qemu-sys661root2001313m188m2752S2.04.90:39.44qemu-sys867root200152601312960R0.30.00:00.07top1root2001944415601252S0.00.00:00.34init2root200000S0.00.00:00.02kthreadd....
在top中也可以查看进程(进程)在哪个CPU上执行的。
执行top后,按f,按j(选中* J: P = Last used cpu (SMP)),然后按空格或回车退出设置,在top的显示中会多出P这一列是最近一次运行该线程(进程)的CPU。
PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+PCOMMAND661root2001313m188m2752S2.34.90:44.243qemu-sys660root2001313m188m2752S2.04.90:51.740qemu-sys874root200152601284860R0.70.00:00.322top1root2001944415601252S0.00.00:00.340init2root200000S0.00.00:00.021kthreadd