文档章节

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
2018/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
2018/10/24
0
0
gdb多线程调试2

一直对GDB多线程调试接触不多,最近因为工作有了一些接触,简单作点记录吧。 先介绍一下GDB多线程调试的基本命令。 info threads 显示当前可调试的所有线程,每个线程会有一个GDB为其分配的I...

长平狐
2012/09/03
324
0
Linux下查看进程和线程的方法

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

井然有序
2018/06/26
0
0
Android 多线程系统概述及与Linux系统的关系

线程系统的分类 1.1 操作系统内核实现了线程模型(核心型线程) - Windows - 线程与进程的多对多模型 线程效率比较高 Window Thread结构如下图所示: 1.2 操作系统核外实现的线程(用户进程)...

长平狐
2012/09/03
220
0

没有更多内容

加载失败,请刷新页面

加载更多

发布xxl-job executor dotnet core 执行器的实现

DotXxlJob [github][https://github.com/xuanye/DotXxlJob] xxl-job的dotnet core 执行器实现,支持XXL-JOB 2.0+ 1 XXL-JOB概述 [XXL-JOB][1]是一个轻量级分布式任务调度平台,其核心设计目标...

假正经哥哥
43分钟前
2
0
mysql 查询当天、本周,本月,上一个月的数据

今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1 近7天 SELECT * FROM 表名 wher......

BraveLN
今天
3
0
Spring 事务初始化源码分析

相关文章 Spring 事务使用详解 Spring AOP 创建代理的源码解析 Spring AOP 注解方式源码解析 Spring AOP 功能使用详解 Spring 的 getBean 方法源码解析 Spring bean 创建过程源码解析 Spring...

TSMYK
今天
1
0
Android Multimedia框架总结(六)C++中MediaPlayer的C/S架构

前面几节中,都是通过java层调用到jni中,jni向下到c++层并未介绍 看下Java层一个方法在c++层 MediaPlayer后续过程 frameworks/av/media/libmedia/MediaPlayer.cpp 找一个我们之前熟悉的setDa...

天王盖地虎626
今天
3
0
【Linux】【MySQL】CentOS7安装最新版MySQL8.0.13(最新版MySQL从安装到运行)

1、前言   框框博客在线报时:2018-11-07 19:31:06   当前MySQL最新版本:8.0.13 (听说比5.7快2倍)   官方之前表示:MySQL 8.0 正式版 8.0.11 已发布,MySQL 8 要比 MySQL 5.7 快 2 ...

Code辉
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部