`

Linux下查看进程和线程

阅读更多
在linux中查看线程数的三种方法
1、top -H
手册中说:-H : Threads toggle
加上这个选项启动top,top一行显示一个线程。否则,它一行显示一个进程。
2、ps xH
手册中说:H Show threads as if they were processes
这样可以查看所有存在的线程。
3、ps -mp <PID>
手册中说:m Show threads after processes
这样可以查看一个进程起的线程数。
 

查看进程

1. top 命令

top命令查看系统的资源状况

  load average表示在过去的一段时间内有多少个进程企图独占CPU

  zombie 进程 :不是异常情况。一个进程从创建到结束在最后那一段时间遍是僵尸。留在内存中等待父进程取的东西便是僵尸。任何程序都有僵尸状态,它占用一点内存资源,仅仅是表象而已不必害怕。如果程序有问题有机会遇见,解决大批量僵尸简单有效的办法是重起。kill是无任何效果的stop模式:与sleep进程应区别,sleep会主动放弃cpu,而stop是被动放弃cpu ,例单步跟踪,stop(暂停)的进程是无法自己回到运行状态的。

  cpu states:

  nice:让出百分比irq:中断处理占用

  idle:空间占用百分比 iowait:输入输出等待(如果它很大说明外存有瓶颈,需要升级硬盘(SCSI))

  Mem:内存情况

  设计思想:把资源省下来不用便是浪费,如添加内存后free值会不变,buff值会增大。 判断物理内存够不够,看交换分区的使用状态。

  交互命令:

  [Space]立即刷新显示

  [h]显示帮助屏幕

  [k] 杀死某进程。你会被提示输入进程 ID 以及要发送给它的信号。 一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。

  [n] 改变显示的进程数量。你会被提示输入数量。

  [u] 按用户排序。

  [M] 按内存用量排序。

  [o][O] 改变显示项目的顺序。

  [P] 根据CPU使用百分比大小进行排序。

  [T] 根据时间/累计时间进行排序。

  [Ctrl+L] 擦除并且重写屏幕。

  [q] 退出程序。

  [r] 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。

  [S] 切换到累计模式。

  [s] 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。

  缩写含义:

  PID每个进程的ID

  USER进程所有者的用户名

  PRI每个进程的优先级别

  NI每个优先级的值

  SIZE 进程的代码大小加上数据大小再加上堆栈空间大小的总数,单位是KB RSS 进程占用的物理内存的总数量,单位是KB

  SHARE进程使用共享内存的数量

  STAT 进程的状态。其中S代表休眠状态;D代表不可中断的休眠状态;R代表运行状态;Z代表僵死状态;T代表停止或跟踪状态

  %CPU进程自最近一次刷新以来所占用的CPU时间和总时间的百分比

  %MEM进程占用的物理内存占总内存的百分比

  TIME进程自启动以来所占用的总CPU时间

  CPU CPU标识

  COMMAND进程的命令名称

 

2. ps命令

ps查看当前用户的活动进程,如果加上参数可以显示更多的信息,如-a,显示所有用户的进程

  ps ax :tty值为“?”是守护进程,叫deamon 无终端,大多系统服务是此进程,内核态进程是看不到的

      ps axf :看进程树,以树形方式现实进程列表敲 ,init是1号进程,系统所有进程都是它派生的,杀不掉

      ps axm :会把线程列出来。在linux下进程和线程是统一的,是轻量级进程的两种方式。

  ps axu :显示进程的详细状态。

  vsz:说此进程一共占用了多大物理内存。

  rss:请求常驻内存多少

 

========================================================================================

查看线程

其实linux没有线程,都是用进程模仿的

1. ps -ef f
用树形显示进程和线程,比如说我想找到proftp现在有多少个进程/线程,可以用
$ ps -ef f | grep proftpd
nobody 23117 1 0 Dec23 ? S 0:00 proftpd:   (accepting   connections)   
jack 23121 23117 0 Dec23 ? S 7:57 \_ proftpd: jack - ftpsrv:   IDLE
jack 28944 23117 0 Dec23 ? S 4:56 \_ proftpd: jack - ftpsrv:   IDLE
这样就可以看到proftpd这个进程下面挂了两个线程。
在Linux下面好像因为没有真正的线程,是用进程模拟的,有一个是辅助线程,所以真正程序开的线程应该只有一个。

2. pstree -c也可以达到相同的效果
$ pstree -c | grep proftpd
|-proftpd-+-proftpd
| `-proftpd

 

3. cat /proc/${pid}/status 
可以查看大致的情况

 

4.  pstack

有些系统可以用这个东东,可以查看所有线程的堆栈


如何查看进程中各线程的内存占用情况?

用ps aux只能查看到进程,如果进程里面使用了pthread编程,用什么命令才能查询到进程里的线程资源占用?
ps aux | grep不就是了

 

0
7
分享到:
评论

相关推荐

    linux 进程和线程

    linux下的进程、线程

    在Windows下创建进程和线程的API

    Windows 下创建进程和线程的 API 在 Windows 操作系统中,创建进程和线程是非常重要的一步骤,对于开发者来说,掌握这方面的知识点是非常必要的。下面我们将详细介绍 Windows 下创建进程和线程的 API。 一、实验...

    linux unix下多线程与进程

    总之,Linux和Unix下的进程和线程是系统级编程的重要概念。理解它们的工作原理,熟练运用多线程技术,对于编写高效、可靠的软件至关重要。在实际开发中,应根据需求合理选择进程或线程,充分利用系统资源,提高程序...

    Linux进程、线程和调度(1)

    接下来,我们将详细探讨与Linux进程、线程和调度相关的知识点。 首先,Linux进程是系统分配资源的基本单位,具有独立的地址空间。进程生命周期包括就绪(ready)、运行(running)、睡眠(sleep)、停止(stopped)...

    操作系统课程设计-linux进程与线程的通讯

    在操作系统课程设计中,Linux进程与线程的通信是一个核心且复杂的主题。在这个项目中,学生将深入理解操作系统内核如何管理和协调不同进程和线程之间的数据交换,从而实现高效的任务执行。以下是对这个主题的详细...

    linux 多进程多线程编程

    Linux 多进程多线程编程是指在 Linux 操作系统下使用 C 语言进行多进程和多线程编程的技术。该技术可以大幅度提高程序的执行效率和响应速度,提高系统的并发能力和资源利用率。 1. 创建缺省线程 在 Linux 系统下,...

    \嵌入式linux开发教程之进程与线程--千锋培训

    嵌入式Linux开发教程深入探讨了进程与线程的概念及其在操作系统中的实现,这对于理解和开发高效、并发的嵌入式应用程序至关重要。以下是这些知识点的详细解释: **一、基础知识:线程和进程** 1. **进程**:是操作...

    LINUX系统下多线程与多进程性能分析.pdf

    本文主要讨论了Linux操作系统下多线程和多进程的性能分析。在Linux系统中,使用多进程处理多个任务,会占用很多系统资源(主要是CPU和内存的使用)。因此,Linux系统对这种弊端进行了改进,在用户态实现了多线程处理...

    linux的进程与线程

    详细介绍了linux下的程序、进程、线程的区别与共同点,是学习linux不可多得的好帮手

    linux下多进程多线程写文件

    代码目的是比较write和printf多路写性能。首先fork生成子进程,并且在子进程中重定向标准输出;然后在父子进程中各创建10个线程分别利用printf和write进行写操作;最后通过返回值比较两者性能。

    基于linux的进程和线程控制

    总结来说,这个实训项目涵盖了Linux下的多线程编程、进程间同步、文件I/O以及信号处理等核心概念,是深入理解和应用操作系统原理的良好实践。通过实际编写和调试he.c代码,你将能够更好地掌握这些知识点,并提升在...

    linux-进程和线程

    - **Linux进程地址空间布局**:进程的地址空间通常分为多个区域,包括文本(代码)区、数据区、堆区和栈区。每个进程都有自己独立的地址空间,互不影响。 - **进程特征**:包括独立的内存空间、拥有资源、并发执行...

    Linux下进程及多线程编程

    Linux 下进程及多线程编程 在 Linux 操作系统中,进程和线程是两种基本的并发编程模型。进程是一种独立的执行单元,拥有独立的虚拟地址空间和系统资源,而线程是一种轻量级的进程,可以共享进程的虚拟地址空间和...

    进程和线程的创建 _实验报告.doc

    1.在linux下编写一个应用程序,命名为an_ch2_1b。这个程序不断地输出如下行: Those output come from child,[系统时间] 另外写一个应用程序,命名为an_ch2_1a。这个程序创建一个子进程,执行an_ch2_1b。这个程序...

    Linux系统中进程和线程的通信方式总结

    Linux作为一款广泛使用的开源操作系统,其进程和线程管理机制是其多任务处理能力的核心。在Linux系统中,进程是执行中的程序实例,线程是进程中执行任务的分支。为了实现进程和线程间的高效通信,Linux提供了多种...

    linux上实现多进程和多线程实现同步互斥(源代码)

    在Linux操作系统中,多进程和多线程是两种并发执行的方式,它们在处理并发问题时,经常需要进行同步和互斥操作,以确保数据的一致性和程序的正确性。本篇将详细介绍这两种并发模型以及如何在Linux环境中实现同步互斥...

    Linux下的多进程/线程网络通信

    程序运行之后,用户可以随时终止程序的运行(比如按下CTRL+C),要求两个进程P1和P2在结束前将各自读取的报文数量(N_rev_P1、N_rev_P2)和各自写入Packet文件中报文的数量(N_wrt_P1、N_wrt_P2)分别写入Report...

    linux 进程线程小程序

    本教程“linux 进程线程小程序”将深入探讨这两个概念,以及如何利用信号量、管道和共享内存进行进程间的通信。 首先,让我们了解什么是进程。在Linux系统中,进程是程序的一次动态执行过程,它具有独立的内存空间...

    linux 进程间通信及多线程操作源码

    通过阅读和分析这个源码,我们可以深入了解如何在Linux环境下利用多线程和共享内存进行进程间通信,这对于理解和实践并发编程具有很高的价值。同时,这也为我们提供了设计和实现高效、安全的并发系统的一个实例参考...

Global site tag (gtag.js) - Google Analytics