进程查看工具:pstree、ps

pstree命令:

树状结构显示进程间关系

  • 选项:
     -p:显示PID号
[root@node1 ~]# pstree -p 
systemd(1)─┬─ModemManager(6511)─┬─{ModemManager}(6521)
           │                    └─{ModemManager}(6529)
           ├─NetworkManager(6536)─┬─dhclient(6703)
           │                      ├─{NetworkManager}(6628)
           │                      └─{NetworkManager}(6632)
           ├─VGAuthService(6538)
           ├─abrt-watch-log(6553)
           ├─abrt-watch-log(6556)
           ├─abrtd(6552)
           ├─accounts-daemon(6547)─┬─{accounts-daemon}(6573)
           │                       └─{accounts-daemon}(6575)
           ├─alsactl(6535)
           ├─at-spi-bus-laun(7519)─┬─dbus-daemon(7524)───{dbus-daemon}(7525)
...

ps命令:显示当前进程的状态信息

  • 格式:
     ps [options]

  • 选项有三种风格:

    1. UNIX风格,可以组合使用,前面只能有一个dash;
    2. BSD风格,可以组合使用,前面不能有dash;
    3. GNU长格式,前面有两个dash;
  • 常用组合之一:aux
     a:所有与终端相关的进程;
     x:所有与终端无关的进程;
     u:以用户为中心组织进程状态信息显示;

    • 字段信息:
       VSZ:虚拟内存集;
       RSS:常驻内存集;
       TTY:与终端相关;
       STAT:运行状态;
        R:running(运行态)
        S:interruptable sleeping(可中断睡眠)
        D:uninterruptable sleeping(不可中断睡眠)
        T:Stopped(停止态)
        Z:zomble(僵死态)
        +:前台进程
        l:多线程进程
        N:低优先级进程
        <:高优先级进程
        s:session leader(会话主导者)
       START:进程启动时间;
       COMMAND:启动此进程的命令;
    [root@node1 ~]# ps aux
    USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root          1  0.0  0.6 128140  6860 ?        Ss   13:04   0:01 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
    root          2  0.0  0.0      0     0 ?        S    13:04   0:00 [kthreadd]
    root          3  0.0  0.0      0     0 ?        S    13:04   0:00 [ksoftirqd/0]
    root          5  0.0  0.0      0     0 ?        S<   13:04   0:00 [kworker/0:0H]
    root          7  0.0  0.0      0     0 ?        S    13:04   0:00 [migration/0]
    root          8  0.0  0.0      0     0 ?        S    13:04   0:00 [rcu_bh]
    root          9  0.0  0.0      0     0 ?        R    13:04   0:00 [rcu_sched]
    root         10  0.0  0.0      0     0 ?        S<   13:04   0:00 [lru-add-drain]
    root         11  0.0  0.0      0     0 ?        S    13:04   0:00 [watchdog/0]
    root         13  0.0  0.0      0     0 ?        S    13:04   0:00 [kdevtmpfs]
    root         14  0.0  0.0      0     0 ?        S<   13:04   0:00 [netns]
    ...
    
  • 常用组合之二:-ef
     -e:显示所有进程;
     -f:显示完整格式的进程信息;

    • 字段信息:
       PPID:父进程ID;
       C:CPU的占用百分比;
       PSR:运行于哪个CPU核心;
       STIME:进程启动时间;
       TTY:与终端相关;
       TIME:累计运行时间;
       CMD:启动此进程的命令;
    [root@node1 ~]# ps -ef
    UID         PID   PPID  C STIME TTY          TIME CMD
    root          1      0  0 13:04 ?        00:00:01 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
    root          2      0  0 13:04 ?        00:00:00 [kthreadd]
    root          3      2  0 13:04 ?        00:00:00 [ksoftirqd/0]
    root          5      2  0 13:04 ?        00:00:00 [kworker/0:0H]
    root          7      2  0 13:04 ?        00:00:00 [migration/0]
    root          8      2  0 13:04 ?        00:00:00 [rcu_bh]
    root          9      2  0 13:04 ?        00:00:00 [rcu_sched]
    root         10      2  0 13:04 ?        00:00:00 [lru-add-drain]
    root         11      2  0 13:04 ?        00:00:00 [watchdog/0]
    ...
    
  • 常用组合之三:-eFH
     -e:显示所有进程;
     -F:显示完整格式的进程信息;
     -H:以层级结构显示进程的相关信息;

    [root@node1 ~]# ps -eFH
    root          1      0  0 32035  6860   0 13:04 ?        00:00:01 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
    root       2983      1  0  9459  3600   0 13:04 ?        00:00:00   /usr/lib/systemd/systemd-journald
    root       3009      1  0 29788  4072   0 13:04 ?        00:00:00   /usr/sbin/lvmetad -f
    root       3015      1  0 12314  6540   0 13:04 ?        00:00:00   /usr/lib/systemd/systemd-udevd
    root       6485      1  0 15511  1084   0 13:04 ?        00:00:00   /sbin/auditd
    root       6487   6485  0 21138   916   0 13:04 ?        00:00:00     /sbin/audispd
    root       6489   6487  0 13907  1400   0 13:04 ?        00:00:00       /usr/sbin/sedispatch
    root       6511      1  0 107650 7584   0 13:04 ?        00:00:00   /usr/sbin/ModemManager
    root       6513      1  0 14378  2564   0 13:04 ?        00:00:00   /usr/libexec/bluetooth/bluetoothd
    dbus       6514      1  0 17445  3504   0 13:04 ?        00:00:00   /usr/bin/dbus-daemon --system --address=systemd: --nofork --nopidfile --systemd-activation
    rpc        6518      1  0 18412  1380   0 13:04 ?        00:00:00   /sbin/rpcbind -w
    avahi      6525      1  0 15569  2316   0 13:04 ?        00:00:00   avahi-daemon: running [node1.local]
    avahi      6541   6525  0 15536   392   0 13:04 ?        00:00:00     avahi-daemon: chroot helper
    libstor+   6534      1  0  2144   820   0 13:04 ?        00:00:00   /usr/bin/lsmd -d
    ...
    
  • 常用组合之四:-eo | axo
     o field1,field2,...:自定义要显示的字段列表,以逗号分隔;
      常用的field:
       pid:进程ID;
       ni:nice值(-20至19),nice值越小,优先级越高;
       priority:优先级;
       rtprio:实时优先级;
       psr:运行于哪个CPU核心;
       pcpu:CPU使用百分比;
       stat:运行状态;
       comm:启动此进程的命令;
       tty:与终端相关;
       ppid:父进程ID;
       ...

    [root@node1 ~]# ps axo pid,ppid,psr,pcpu,stat,comm    
       PID   PPID PSR %CPU STAT COMMAND
         1      0   0  0.0 Ss   systemd
         2      0   0  0.0 S    kthreadd
         3      2   0  0.0 S    ksoftirqd/0
         5      2   0  0.0 S<   kworker/0:0H
         7      2   0  0.0 S    migration/0
         8      2   0  0.0 S    rcu_bh
         9      2   0  0.0 R    rcu_sched
        10      2   0  0.0 S<   lru-add-drain
        11      2   0  0.0 S    watchdog/0
        13      2   0  0.0 S    kdevtmpfs
        14      2   0  0.0 S<   netns
        15      2   0  0.0 S    khungtaskd
        16      2   0  0.0 S<   writeback
        17      2   0  0.0 S<   kintegrityd
        18      2   0  0.0 S<   bioset
        19      2   0  0.0 S<   bioset
        20      2   0  0.0 S<   bioset
        21      2   0  0.0 S<   kblockd
        22      2   0  0.0 S<   md
        23      2   0  0.0 S<   edac-poller
    

ps常见选项

 -C cmdlist:指定命令,多个命令用 "," 分隔
 -L:显示线程
 -e:显示所有进程,相当于-A
 -f:显示完整格式程序信息
 -F:显示更完整格式的进程信息
 -H:以进程层级格式显示进程相关信息
 -u userlist:指定有效的用户ID或名称
 -U userlist:指定真正的用户ID或名称
 -g gid 或 groupname:指定有效的gid或组名称
 -G gid 或 groupname:指定真正的gid或组名称
 -p PID:显示指定pid的进程
 --ppid PID:显示属于pid的子进程
 -M:显示SELinux信息,相当于Z

ps示例:

  • 查询你拥有的所有进程:
    ~]# ps -x
  • 显示指定用户名(RUID)或用户ID的进程:
    ~]# ps -fU apache
    ~]# ps -fu 48
  • 显示指定用户名(EUID)或用户ID的进程:
    ~]# ps -fu wang
    ~]# ps -fu 1000
  • 查看以root用户权限(实际和有效ID)运行的每个进程:
    ~]# ps -U root -u root
  • 列出某个组拥有的所有进程(实际组ID:RGID或名称):
    ~]# ps -fG nginx
  • 列出有效组名称(或会话)所拥有的所有进程:
    ~]# ps -fg mysql
    ~]# ps -fG 27
  • 通过进程ID来显示所属的进程:
    ~]# ps -fp 1234
  • 以父进程ID来显示其下所有的进程,如显示父进程为1154的所有进程:
    ~]# ps -f --ppid 1234
  • 显示指定PID的多个进程:
    ~]# ps -fp 1204,1239,1263
  • 要按tty显示所属进程:
    ~]# ps -ft pst/0
  • 以进程树显示系统中的进程如何相互链接:
    ~]# ps -e --forest
  • 以进程树显示指定的进程
    ~]# ps -f --forest -C sshd
    ~]# ps -ef --forest | grep -v grep | grep sshd
  • 要显示一个进程的所有线程,将显示LWP(轻量级进程)以及NLWP(轻量级进程数)列:
    ~]# ps -fL -C nginx
  • 要列出所有格式说明符:
    ~]# ps L
  • 查看进程的PID,PPID,用户名和命令:
    ~]# ps -eo pid ,ppid,user,cmd
  • 自定义格式显示文件系统组,ni值开始时间和进程的时间
    ~]# ps -p 1234 -o pid,ppid,fgroup,ni,lstart,etime
  • 使用其PID查找进程名称:
    ~]# ps -p 1244 -o comm=
  • 要以其名称选择特定进程,显示其所有子进程
    ~]# ps -C sshd,bash
  • 查找指定进程名所有的所属PID,在编写需要从std输出或文件读取PID的脚本时,这个参数很有用:
    ~]# ps -C httpd,sshd -o pid=
  • 检查一个进程的执行时间
    ~]# ps -eo comm,etime,user | grep nginx
  • 查找占用最多内存和CPU的进程:
    ~]# ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem | head
    ~]# ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%cpu | head
  • 显示安全信息:
    ~]# ps -eM
    ~]# ps --context
  • 使用以下命令以用户定义的格式显示安全信息:
    ~]# ps -eo euser,ruser,suser,fuser,f,comm,label
  • 使用watch实用程序执行重复的输出以实现对就进程行实时的监视,如下面的命令显示每秒钟的监视:
    ~]# watch -n 1 'ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem | head'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容