您当前的位置:首页 > 电脑百科 > 软件技术 > 操作系统 > linux

Linux 使用ps命令监视进程状态

时间:2020-06-29 11:43:11  来源:  作者:
Linux 使用ps命令监视进程状态

 

前言

ps命令——查看静态的进程状态(Processes Statistics)

目录

一、描述

二、命令

三、示例

四、总结

五、思维导图

一、描述

1、作用

  • 查看静态的进程状态(Processes Statistics)

ps命令是linux系统中最为常用的进程查看工具,主要用于显示包含当前运行的各进程完整信息的静态快照。

2、进程状态

  • D:无法中断的休眠状态(通常为IO进程)
  • R:正在运行以及可运行状态(在运行队列中)
  • S:可以中断的休眠状态(等待某一时间的完成)
  • T:暂停执行
  • t:在跟踪期间被调试器停止
  • W:没有足够的记忆体分页可分配
  • X:已死亡
  • Z:不存在但暂时无法消除

对于BSD格式,当使用stat关键字时,可能会显示其他字符:

  • <:优先级更高的进程
  • N:优先级更低的进程
  • L:将页面锁定到内存中(用于实时和自定义IO)
  • s:是一个session的领导者
  • l:是一个多线程
  • +:是一个在后台运行的项目组

3、优先级——nice、priority

  • 以数字形式给内核表示进程的优先级
  • NI的值越高,优先级越低
  • NI值越低或负,则表示优先级越高
  • NI的取值范围:-20 ~ 19
  • priority的值越小越早被执行

二、命令

1、语法

ps [options]

2、常用选项介绍

  • [ -a ]:显示当前终端所有(all)用户的进程(包括其他用户的)
  • [ u ]:使用以用户(user)为主的格式输出进程信息
  • [ -u ] 用户名:显示特定用户的进程
  • [ -x ]:显示当前用户没有控制终端的进程
  • [ -l ]:使用长(long)格式显示进程信息
  • [ -w ]:宽行显示,可以使用多个w进行加宽显示
  • [ -e ]:显示系统内的所有(every)进程(包含用户进程、没有控制终端系统进程)信息
  • [ -f ]:使用完整(Full)的格式显示进程信息
  • [ -A ]:列出所有进程

注意:选项带" - "和不带前缀" - "是有区别的。

3、命令返回字段含义

命令返回的结果是以列表形式出现的,列表中主要字段的含义如下:

  • USER:启动该进程的用户名,即进程所有者的用户名
  • UID:进程所属的用户ID,在当前系统中是唯一的
  • PID(Process ID):该进程在系统中的标识号(ID号)
  • PPID:进程的父进程标识号
  • %CPU:该进程占用的CPU使用率
  • %MEM:该进程占用的物理内存和总内存的百分比
  • TTY:表明该进程在哪个终端上运行(" ? "标识为未知或不需要终端)
  • VSZ/VIRT:占用的虚拟内存(swap空间)的大小(单位:KB)
  • RSS/RES:占用的固定内存(物理内存)的大小(单位:KB)
  • SHR:进程使用的共享内存的大小(单位:KB)
  • COMMAND/CMD:启动该进程的命令的名称。列中的信息用中括号(" [ ] ")括起来则说明该进程为内核线程(Kernel thread),一般以k开头
  • TIME:实际使用CPU的时间
  • STIME:进程的启动时间
  • TIME+:进程启动后占用的总的CPU时间(CPU使用时间的累加)
  • STAT/S:进程当前的状态
  • START:启动该进程的时间
  • PRI/PR:进程的优先级(priority)
  • NI:进程的友善度(niceness)

三、示例

1、使用标准语法查看系统上的所有进程

[root@localhost ~]# ps -ejH
   PID   PGID    SID TTY          TIME CMD
     2      0      0 ?        00:00:00 kthreadd
     4      0      0 ?        00:00:00   kworker/0:0H
     5      0      0 ?        00:00:00   kworker/u256:0
......
 
 [root@localhost ~]# ps axjf
  PPID    PID   PGID    SID TTY       TPGID STAT   UID   TIME COMMAND
     0      2      0      0 ?            -1 S        0   0:00 [kthreadd]
     2      4      0      0 ?            -1 S<       0   0:00  _ [kworker/0:0H]
     2      5      0      0 ?            -1 S        0   0:00  _ [kworker/u256:0]
......

2、使用BSD格式查看所有进程

[root@localhost ~]# ps -eLf
UID         PID   PPID    LWP  C NLWP STIME TTY          TIME CMD
root          1      0      1  0    1 15:02 ?        00:00:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
root          2      0      2  0    1 15:02 ?        00:00:00 [kthreadd]
root          4      2      4  0    1 15:02 ?        00:00:00 [kworker/0:0H]
......

[root@localhost ~]# ps axms
  UID    PID          PENDING          BLOCKED          IGNORED           CAUGHT STAT TTY        TIME COMMAND
    0      1 0000000000000000                -                -                - -    ?          0:02 /usr/lib/systemd/systemd --switched-root --system --deserialize
    0      - 0000000000000000 7be3c0fe28014a03 0000000000001000 00000001800004ec Ss   -          0:02 -
    0      2 0000000000000000                -                -                - -    ?          0:00 [kthreadd]
......

3、打印进程树

[root@localhost ~]# ps -eo euser,ruser,suser,fuser,f,comm,label
EUSER    RUSER    SUSER    FUSER    F COMMAND         LABEL
root     root     root     root     4 systemd         system_u:system_r:init_t:s0
root     root     root     root     1 kthreadd        system_u:system_r:kernel_t:s0
root     root     root     root     1 kworker/0:0H    system_u:system_r:kernel_t:s0
......
 
 [root@localhost ~]# ps axZ
LABEL                              PID TTY      STAT   TIME COMMAND
system_u:system_r:init_t:s0          1 ?        Ss     0:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
system_u:system_r:kernel_t:s0        2 ?        S      0:00 [kthreadd]
system_u:system_r:kernel_t:s0        4 ?        S<     0:00 [kworker/0:0H]
......

[root@localhost ~]# ps -eM
LABEL                              PID TTY          TIME CMD
system_u:system_r:init_t:s0          1 ?        00:00:02 systemd
system_u:system_r:kernel_t:s0        2 ?        00:00:00 kthreadd
system_u:system_r:kernel_t:s0        4 ?        00:00:00 kworker/0:0H

4、获取关于线程的信息

[root@localhost ~]# ps -eLf
UID         PID   PPID    LWP  C NLWP STIME TTY          TIME CMD
root          1      0      1  0    1 15:02 ?        00:00:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
root          2      0      2  0    1 15:02 ?        00:00:00 [kthreadd]
root          4      2      4  0    1 15:02 ?        00:00:00 [kworker/0:0H]
......

[root@localhost ~]# ps axms
  UID    PID          PENDING          BLOCKED          IGNORED           CAUGHT STAT TTY        TIME COMMAND
    0      1 0000000000000000                -                -                - -    ?          0:02 /usr/lib/systemd/systemd --switched-root --system --deserialize
    0      - 0000000000000000 7be3c0fe28014a03 0000000000001000 00000001800004ec Ss   -          0:02 -
    0      2 0000000000000000                -                -                - -    ?          0:00 [kthreadd]
......

5、获取安全的信息

[root@localhost ~]# ps -eo euser,ruser,suser,fuser,f,comm,label
EUSER    RUSER    SUSER    FUSER    F COMMAND         LABEL
root     root     root     root     4 systemd         system_u:system_r:init_t:s0
root     root     root     root     1 kthreadd        system_u:system_r:kernel_t:s0
root     root     root     root     1 kworker/0:0H    system_u:system_r:kernel_t:s0
......
 
 [root@localhost ~]# ps axZ
LABEL                              PID TTY      STAT   TIME COMMAND
system_u:system_r:init_t:s0          1 ?        Ss     0:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
system_u:system_r:kernel_t:s0        2 ?        S      0:00 [kthreadd]
system_u:system_r:kernel_t:s0        4 ?        S<     0:00 [kworker/0:0H]
......

[root@localhost ~]# ps -eM
LABEL                              PID TTY          TIME CMD
system_u:system_r:init_t:s0          1 ?        00:00:02 systemd
system_u:system_r:kernel_t:s0        2 ?        00:00:00 kthreadd
system_u:system_r:kernel_t:s0        4 ?        00:00:00 kworker/0:0H

四、总结

  • ps显示有关活动进程的信息
  • 是Linux系统中最为常用的进程查看工具
  • ps语法:ps [options]

五、思维导图

Linux 使用ps命令监视进程状态

 



Tags:Linux ps命令   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
前言ps命令&mdash;&mdash;查看静态的进程状态(Processes Statistics)目录一、描述二、命令三、示例四、总结五、思维导图一、描述1、作用 查看静态的进程状态(Processes Stati...【详细内容】
2020-06-29  Tags: Linux ps命令  点击:(98)  评论:(0)  加入收藏
▌简易百科推荐
作用显示文件或目录所占用的磁盘空间使用命令格式du [option] 文件/目录命令功能显示文件或目录所占用的磁盘空间一些写法的区别du -sh xxx 显示总目录的大小,但是不会列出...【详细内容】
2021-12-23  mitsuhide1992    Tags:du命令   点击:(12)  评论:(0)  加入收藏
什么是linux内核linux就像是一个哲学的最佳实践。如果非要对它评价,我真的不知道该怎么赞叹,我只能自豪地说着:“linux的美丽简直让人沉醉。”我只能说是我处在linux学习的修炼...【详细内容】
2021-12-23  linux上的码农    Tags:linux内核   点击:(15)  评论:(0)  加入收藏
本文将比较 Linux 中 service 和 systemctl 命令,先分别简单介绍这两个命令的基础用法,然后进行比较。从 CentOS 7.x 开始,CentOS 开始使用 systemd 服务来代替 service服务(dae...【详细内容】
2021-12-23  软件架构    Tags:systemctl   点击:(14)  评论:(0)  加入收藏
mv是move的缩写,可以用来移动文件或者重命名文件名,经常用来备份文件或者目录。命令格式mv [选项] 源文件或者目录 目标文件或者目录命令功能mv命令中第二个参数类型的不同(...【详细内容】
2021-12-17  入门小站    Tags:mv命令   点击:(23)  评论:(0)  加入收藏
大数据技术AI Flink/Spark/Hadoop/数仓,数据分析、面试,源码解读等干货学习资料 98篇原创内容 -->公众号 Linux sed 命令是利用脚本来处理文本文件。sed 可依照脚本的指令来处...【详细内容】
2021-12-17  仙风道骨的宝石骑士    Tags:sed命令   点击:(22)  评论:(0)  加入收藏
Node是个啥?  写个东西还是尽量面面俱到吧,所以有关基本概念的东西我也从网上选择性地拿了下来,有些地方针对自己的理解有所改动,对这些概念性的东西有过了解的可选择跳过这段...【详细内容】
2021-12-15  linux上的码农    Tags:node   点击:(25)  评论:(0)  加入收藏
难道只有我一个人觉得Ubuntu的unity桌面非常好用吗?最近把台式机上面的Ubuntu 16.04格式化了,装了黑苹果用了一周,不得不说,MacOS确实很精美,软件生态比Linux丰富很多,比Windows简...【详细内容】
2021-12-14  地球末日村    Tags:ubuntu   点击:(40)  评论:(0)  加入收藏
简介Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Memberships) 等等。输出信息含义执行net...【详细内容】
2021-12-13  窥镜天    Tags:Linux netstat   点击:(28)  评论:(0)  加入收藏
对于较多数量的文件描述符的监听无论是select还是poll系统调用都显得捉襟见肘,poll每次都需要将所有的文件描述符复制到内核,内核本身不会对这些文件描述符加以保存,这样的设计...【详细内容】
2021-12-13  深度Linux    Tags:Linux   点击:(19)  评论:(0)  加入收藏
今天,我们来了解下 Linux 系统的革命性通用执行引擎-eBPF,之所以聊着玩意,因为它确实牛逼,作为一项底层技术,在现在的云原生生态领域中起着举足轻重的作用。截至目前,业界使用范...【详细内容】
2021-12-10  架构驿站    Tags:eBPF   点击:(29)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条