文档章节

Linux中查看进程的多线程

完美世界
 完美世界
发布于 2014/06/04 23:19
字数 783
阅读 18
收藏 1

在SMP系统中,我们的应用程序经常使用多线程的技术,那么在Linux中如何查看某个进程的多个线程呢?

本文介绍3种命令来查看Linux系统中的线程(LWP)的情况:

在我的系统中,用qemu-system-x86_64命令启动了一个SMP的Guest,所以有几个qemu的线程,以此为例来说明。

1. pstree 命令

查看进程和线程的树形结构关系

[root@jay-linux ~]# pstree | grep qemu
|-terminal-+-bash—qemu-sys—2*[{qemu-system-x8}]
[root@jay-linux ~]# pstree -p | grep qemu
|-terminal(194)-+-bash(196)—qemu-sys(657)-+-{qemu}(660)
|	   |	                 `-{qemu}(661)

2. ps 命令

-L参数显示进程,并尽量显示其LWP(线程ID)和NLWP(线程的个数)。

[root@jay-linux ~]# ps -eLf | grep qemu
root	 657 196 657  0	3 13:48 pts/1	00:00:00 qemu-sys -m 1024 -smp 2
root	 657 196 660  3	3 13:48 pts/1	00:00:26 qemu-sys -m 1024 -smp 2
root	 657 196 661  2	3 13:48 pts/1	00:00:19 qemu-sys -m 1024 -smp 2
root	 789  9799 10789  0	1 14:02 pts/0	00:00:00 grep –color=auto qemu

上面命令查询结果的第二列为PID,第三列为PPID,第四列为LWP,第六列为NLWP。

另外,ps命令还可以查看线程在哪个CPU上运行,命令如下:

[root@jay-linux ~]# ps -eo ruser,pid,ppid,lwp,psr,args -L | grep qemu
root	 657 196 657   1 qemu-sys -hda smep-temp.qcow -m 1024 -smp 2
root	 657 196 660   1 qemu-sys -hda smep-temp.qcow -m 1024 -smp 2
root	 657 196 661   2 qemu-sys -hda smep-temp.qcow -m 1024 -smp 2
root	 834  9799 10834   1 grep –color=auto qemu

其中,每一列依次为:用户ID,进程ID,父进程ID,线程ID,运行该线程的CPU的序号,命令行参数(包括命令本身)。

3. top 命令

其中H命令可以显示各个线程的情况。(在top命令后,按H键;或者top -H)

[root@jay-linux ~]# top -H
top – 14:18:20 up 22:32,  4 users,  load average: 2.00, 1.99, 1.90
Tasks: 286 total,   1 running, 285 sleeping,   0 stopped,   0 zombie
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:   3943892k total,  1541540k used,  2402352k free,   164404k buffers
Swap:  4194300k total,	 0k used,  4194300k free,   787768k cached
  PID USER	  PR  NI  VIRT  RES  SHR S %CPU %MEM	TIME+  COMMAND
660 root	  20   0 1313m 188m 2752 S  2.3  4.9   0:46.78 qemu-sys
661 root	  20   0 1313m 188m 2752 S  2.0  4.9   0:39.44 qemu-sys
867 root	  20   0 15260 1312  960 R  0.3  0.0   0:00.07 top
1 root	  20   0 19444 1560 1252 S  0.0  0.0   0:00.34 init
2 root	  20   0	 0	0	0 S  0.0  0.0   0:00.02 kthreadd
….

在top中也可以查看进程(进程)在哪个CPU上执行的。

执行top后,按f,按j(选中* J: P = Last used cpu (SMP)),然后按空格或回车退出设置,在top的显示中会多出P这一列是最近一次运行该线程(进程)的CPU.

PID USER	  PR  NI  VIRT  RES  SHR S %CPU %MEM	TIME+  P COMMAND
661 root	  20   0 1313m 188m 2752 S  2.3  4.9   0:44.24 3 qemu-sys
660 root	  20   0 1313m 188m 2752 S  2.0  4.9   0:51.74 0 qemu-sys
874 root	  20   0 15260 1284  860 R  0.7  0.0   0:00.32 2 top
1 root	  20   0 19444 1560 1252 S  0.0  0.0   0:00.34 0 init
2 root	  20   0	 0	0	0 S  0.0  0.0   0:00.02 1 kthreadd

更多信息,请 man pstree, man top, man ps 查看帮助文档。

注: LWP为轻量级进程(即:线程),(light weight process, or thread) 。


© 著作权归作者所有

共有 人打赏支持
完美世界
粉丝 10
博文 151
码字总数 134011
作品 0
西城
高级程序员
私信 提问
Linux基础 30分钟GDB调试快速突破

引言 Linus心灵鸡汤   在*nix开发中有道卡叫gdb调试,不管你怎么搞. 它依然在那丝毫不会松动.今天致敬一个 活着的传奇 Linus Torvalds   Unix 始于上个世纪60年代,在70年代得到了迅猛的发...

xumaojun
04/23
0
0
日常运维命令 iostat、free、ps aux、netstat -lnp、tcpdump等命令用法

10月24日任务 10.6 监控io性能 10.7 free命令 10.8 ps命令 10.9 查看网络状态 10.10 linux下抓包 10.6 、监控io性能 监控系统状态 iostat -x 命令,最重要关注的指标%util, 表示io等待,磁盘...

zgxlinux
10/24
0
0
Linux下查看进程和线程的方法

篇一 : Linux下查看进程和线程的方法 在Linux中查看线程数的三种方法 1、top -H 手册中说:-H : Threads toggle 加上这个选项启动top,top一行显示一个线程。否则,它一行显示一个进程。 2、...

井然有序
06/26
0
0
Linux多进程和多线程的一次gdb调试实例

Linux C/C++开发中gdb进行多进程和多线程的调试一直比较麻烦,在CSDN上看到高科的一篇文章《gdb调试多进程和多线程命令》比较有启发,这里就自己重新整理并做了一个GDB多进程/线程的调试实践...

mskk
01/16
0
0
嵌入式Linux学习基础规划篇

嵌入式的学习是需要日积月累的,是通过一点一滴的积累才能成为大神。下面来介绍一下嵌入式linux学习基础规划,目标是达到适应嵌入式应用软件开发、嵌入式系统开发或嵌入式驱动开发的基本素质...

创客学院
04/10
0
0

没有更多内容

加载失败,请刷新页面

加载更多

docker部署springboot项目

安装docker 菜鸟教程 springboot项目 maven依赖 <?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001......

yimingkeji
今天
9
0
ios多个target

1.建立3个target,分别为heroone,heroone test,heroone dev;分别为正式环境,test环境,dev环境 2.注意取消掉autocreate以防止名字不对,分别以Duplicate的方式建立另外两个scheme 3.创建...

HeroHY
今天
5
0
php获取客户端IP

php获取客户端IP 首先先阅读关于IP真实性安全的文章:如何正確的取得使用者 IP? 「任何從客戶端取得的資料都是不可信任的!」 HTTP_CLIENT_IP头是有的,但未成标准,不一定服务器都实现。 ...

DrChenXX
昨天
0
0
. The valid characters are defined in RFC 7230 and RFC 问题

通过这里的回答,我们可以知道: Tomcat在 7.0.73, 8.0.39, 8.5.7 版本后,添加了对于http头的验证。 具体来说,就是添加了些规则去限制HTTP头的规范性 参考这里 具体来说: org.apache.tom...

west_coast
昨天
1
0
刷leetcode第704题-二分查找

今天双十一买的算法书到货了,路上刷到有人说的这个题,借(chao)鉴(xi)一下别人的思路,这个是C++标准库里面的经典方法,思路精巧,优雅好品味 int search(int* nums, int numsSize, in...

锟斤拷烫烫烫
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部