进程的查看与控制 小结

一、查看和控制进程

程序是保存在外部存储介质(如硬盘、光盘)中的可执行机器代码和数据的静态集合,而进程是在cpu及内存中处于动态执行状态的计算机程序。在linux系统中,每个程序启动后可以创建一个或者多个进程.

1.1 查看进程

  • 了解系统中进程的状态是对进程进行管理的前提,使用不同的命令工具可以从不同的角度查看进程状态,下面将使用常用的进程查看命令查看进程。

1.1.1 PS命令——查看静态的进程统计信息(Processes Statistic)

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

  • a:显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将显示系统中所有的进程信息。
  • u:使用以用户为主的格式输出进程信息。
  • x:显示当前用户在所有终端下的进程信息
  • -e:显示系统内的所有进程信息
  • -l:使用长(Long)格式显示进程信息。
  • -f:使用完整的(Full)格式显示进程信息。
    以上为PS命令中几个常用的几个选项,需要注意的是,有一部分选项是不带”-“前缀的(添加”-“前缀后含义可能会有出入,详情参考man手册)。习惯将上述选项组合在一起使用。如:”ps aux“,”ps -elf“。
[root@localhost ~]# ps aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  0.0  0.1 128116  6716 ?        Ss   13:40   0:02 /usr/lib/systemd
root          2  0.0  0.0      0     0 ?        S    13:40   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    13:40   0:00 [ksoftirqd/0]
root          5  0.0  0.0      0     0 ?        S<   13:40   0:00 [kworker/0:0H]
root          7  0.0  0.0      0     0 ?        S    13:40   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    13:40   0:00 [rcu_bh]
root          9  0.0  0.0      0     0 ?        S    13:40   0:01 [rcu_sched]
root         10  0.0  0.0      0     0 ?        S<   13:40   0:00 [lru-add-drain]
root         11  0.0  0.0      0     0 ?        S    13:40   0:00 [watchdog/0]
root         12  0.0  0.0      0     0 ?        S    13:40   0:00 [watchdog/1]

上述输出信息中,第一行为列表标题,各字段的含义如下描述

  • USER:启动该程序的用户账号的名称
  • PID:该进程在系统中的数字ID号,在当前系统中是唯一的。
  • TTY:表明该进程在哪个终端上运行。”?“表示位置或不需要终端。
  • STAT:显示了进程当前的状态,S(休眠)、R(运行)、Z(僵死)、<(高优先级)、N(低优先级)、s(父进程)、+(前台进程)。对于僵死状态的进程应予以手动终止。
  • START:启动该进程的时间。
  • COMMAND:启动该进程的命令的名称
  • %CPU:CPU占用的百分比
  • %MEM:内存占用的百分比
    -VSZ:占用虚拟内存(swap空间)的大小。
    RSS:占用常驻内存(物理内存)的大小。

直接执行不带任何选项的ps命令时,将只显示当前用户会话中打开的进程。

[root@localhost ~]# ps
   PID TTY          TIME CMD
 11136 pts/1    00:00:00 bash
 11167 pts/1    00:00:00 ps
  • 由于系统中运行的进程数量较多,需要查询某一个进程的信息时可以结合管道操作和grep命令进行过滤。
  • 执行以下操作可以过滤出包含”bash“的进程信息
[root@localhost ~]# ps aux|grep bash
root       9938  0.0  0.0 115936  2548 tty1     Ss+  13:51   0:00 -bash
root      10776  0.0  0.0 116320  2852 pts/0    Ss+  14:00   0:00 -bash
root      11136  0.0  0.0 115932  2464 pts/1    Ss   16:14   0:00 -bash
root      11186  0.0  0.0 112824   980 pts/1    S+   17:01   0:00 grep --color=auto bash

1.1.2 Top——查看进程动态信息。

  • 使用ps命令查看到的时一个静态的信息,并不能连续不断地反馈出当前进程的运行状态。若希望以动态刷新的方式显示各进程的状态信息,可以使用top命令。
  • top命令将会在当前终端以全屏交互式的界面显示进程排名,及时跟踪包括CPU,内存等系统资源占用情况,默认情况下每三秒刷新一次,作用类似于Windows系统中的任务管理器。
[root@localhost ~]# top
top - 18:42:45 up 2 min,  1 user,  load average: 0.14, 0.19, 0.08
Tasks: 126 total,   2 running, 124 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.2 us,  0.2 sy,  0.0 ni, 99.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  3861512 total,  3526608 free,   152488 used,   182416 buff/cache
KiB Swap:  4063228 total,  4063228 free,        0 used.  3470812 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND     
    50 root      20   0       0      0      0 S   0.3  0.0   0:00.18 kworker/0:1 
  8856 root      20   0  301040   6488   5116 S   0.3  0.2   0:00.30 vmtoolsd    
  9971 root      20   0  162116   2236   1552 R   0.3  0.1   0:00.13 top         
     1 root      20   0  127980   6588   4136 S   0.0  0.2   0:01.92 systemd     
     2 root      20   0       0      0      0 S   0.0  0.0   0:00.01 kthreadd    
     3 root      20   0       0      0      0 S   0.0  0.0   0:00.09 ksoftirqd/0 
     4 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kworker/0:0 
     5 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/0:0H
     6 root      20   0       0      0      0 S   0.0  0.0   0:00.01 kworker/u25+
     7 root      rt   0       0      0      0 S   0.0  0.0   0:00.11 migration/0 
     8 root      20   0       0      0      0 S   0.0  0.0   0:00.00 rcu_bh      
     9 root      20   0       0      0      0 S   0.0  0.0   0:00.47 rcu_sched   
    10 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 lru-add-dra+
    11 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 watchdog/0  
    12 root      rt   0       0      0      0 S   0.0  0.0   0:00.00 watchdog/1  
    13 root      rt   0       0      0      0 S   0.0  0.0   0:00.03 migration/1 
    14 root      20   0       0      0      0 S   0.0  0.0   0:00.04 ksoftirqd/1 
    15 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kworker/1:0 
    16 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/1:0H
    18 root      20   0       0      0      0 S   0.0  0.0   0:00.02 kdevtmpfs   
    19 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 netns       
    20 root      20   0       0      0      0 S   0.0  0.0   0:00.01 khungtaskd  
    21 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 writeback   
    22 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kintegrityd 
    23 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 bioset      
    24 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 bioset      
    25 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 bioset      
    26 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kblockd     
    27 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 md          
    28 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 edac-polle

上述输出信息中,开头的部分显示了系统任务(Tasks),CPU占用,内存占用(Mem),交换空间(Swap)等汇总信息,汇总信息下方依次显示当前进程的排名情况。相关信息含义如:

  • 系统任务(Tasks)信息:total,总进程数;running,正在运行的进程数;sleeping。休眠的进程数;stopped,中止的进程数;zombie,僵死无响应的进程数

  • CUP占用信息:us,用户占用;sy,内核占用;ni,优先级调度占用;id,空闲CPU;wa,I/O等待占用;hi,硬件中断占用;si,软件中断占用;st,虚拟化占用。要了解空闲的CPU百分比,主要是看%id部分

  • 内存占用(Mem)信息:total,总内存空间;used,已用内存空间;free,空闲内存空间;buffers,缓存区域

  • 交换空间(Swap)占用:total,总交换空间;used,已用交换空间;free,空闲交换空间;cached,缓存空间

  • 操作选项
    M:以内存大小排序
    c:以CPU占用排序
    h:top程序在线帮助信息
    q:退出

1.1.3 pgrep 命令——查询进程信息

  • 当使用ps命令查询某个进程的PID信息时,往往需要结合grep命令对输出结果进行过滤,很不方便.。
  • pgrep命令是查询特定进程信息的专用工具,使用pgrep命令可以根据进程的名称、运行该进程的用户、进程所在的终端等多种属性查询特定进程的PID号。
  • 通过pgrep命令可以指定进程的一部分名称进行查询,结合“-l"选项可以同时输出对应的进程名。
    例:查询进程中含“log”的进程及PID号。
[root@localhost ~]# pgrep -l "log"
4373 xfs-log/dm-0
7390 xfs-log/sda1
8662 xfs-log/dm-2
8850 systemd-logind
9437 rsyslogd
  • 结合选项-U查询特定用户的进程,-t选项查询在特定终端运行的进程。
    例:查看用户tom在tty1终端上运行的进程及PID号。
[root@localhost ~]# pgrep -l -U tom -t tty1
27483 bush
27584 vim 

1.1.4 pstree命令(pstree命令的安装)——查看进程数

  • pstree命令以属性结构列出进程信息,可以更直观的判断各进程的相互关系(父,子进程)

  • pstree命令默认情况下只显示各进程的名称

  • “-p”选项,列出对应的PID号

  • “-u”选项,列出对应的用户名

  • “-a”选项,列出完整的命令信息

[root@localhost ~]# pstree -aup    ## 没有pstree命令
-bash: pstree: 未找到命令
[root@localhost ~]# yum -y install psmisc     ## 下载pstree包
已加载插件:fastestmirror
Loading mirror speeds from cached hostfile
 * base: mirrors.aliyun.com
 * extras: mirrors.aliyun.com
 * updates: mirrors.bfsu.edu.cn
正在解决依赖关系
--> 正在检查事务
---> 软件包 psmisc.x86_64.0.22.20-16.el7 将被 安装
--> 解决依赖关系完成
[root@localhost ~]# pstree -aup		'//查看当前系统的进程树(包括各进程对应的PID号,用户名,完整命令等信息)'
systemd,1 --switched-root --system --deserialize 21
  ├─ModemManager,601
  │   ├─{ModemManager},631
  │   └─{ModemManager},635
  ├─NetworkManager,667 --no-daemon
  │   ├─dhclient,791 -d -q -sf /usr/libexec/nm-dhcp-helper -pf...
  │   ├─{NetworkManager},676
  │   └─{NetworkManager},678
..省略部分信息
[root@localhost ~]# pstree -ap tom  ## 查看用户的进程树
bash,10025

1.2 控制进程

1.2.1 启动进程

手工启动

  • Linux系统中可以,用户手工启动进程,按预定计划调度启动新的进程。
  • 进程在前台运行时,用户必须等到该进程执行结束并退出后才能继续输入其他命令。
  • 运行耗时较长的操作可进入后台运行,进程在后台运行时,用户可以继续在当前终端输入其他命令,无需等待该进程结束,适用于运行耗时较长的进程。
  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令末尾加入“&”符号
[root@localhost ~]# cp /dev/cdrom mycd.iso&  ## 在后台进行复制镜像文件进程
[1] 10142   ## 输出信息中心包括后台任务序号,PID号'

调度启动进程

  • 在维护过程中,需要执行一些比较费时而且比较占用资源的任务(如数据备份),这些任务更适合在相对空闲的时候进行,这时候需要事先调度安排,指定任务运行的时间运行,当到指定的时间时,调度启动的计划任务均在后台运行,不会占用用户的命令终端。
  • at命令,设置一次性计划任务(如 12:30重启网络服务)
  • crontab,命令,设置周期性计划任务(如 每周六18:00 备份数据库)

1.2.2 改变进程的运行方式

挂起当前的进程
  • 当linux系统中的命令正在前台执行,按Ctrl+Z组合键可以将当前进程挂起。
查看后台的进程
  • 查看处于后台的任务列表。
  • 结合“-l”选项可以同时显示出该进程对应的PID号
  • 输出结果中,每一行记录对应一个后台进程的状态信息,行首的数字代表该进程在后台的任务编号。
  • 若当前终端没有后台进程,将不会显示任何信息
[root@localhost ~]# jobs -l
[1]+ 10142 完成                  cp -i /dev/cdrom mycd.iso
将后台的进程恢复运行 fg 命令
  • 将后台进程恢复到前台运行,可以指定任务序号
  • bg(BackGround)命令可以将后台中暂停执行的任务恢复运行,继续在后台执行操作
  • fg(ForeGround)命令可以将后台任务恢复到前台运行
  • 除非后台任务只有一个,否则bg和fg命令都需要指定后台进程的任务编号作为参数
终止进程执行
  • 平常可以使用Ctrl + C组合键强制中断
  • Ctrl + C组合键无法中止后,可以使用专门的进程中止工具 kill,killall,pkill
使用kill命令终止进程
  • kill命令需要使用进程的PID号作为参数
  • 若进程无法响应,可结合“-9”选项强行中止进程。强行中止进程可能会到时部分数据丢失,谨慎使用
使用killall命令终止进程
  • killall命令通过进程名来中止进程,可终止指定名称所有进程(可理解为终止进程树)
  • killall命令同样有“-9”选项,强制终止进程
使用pkill命令终止进程

根据特定条件终止相应的进程

常用命令选项:

-U:根据进程所属的用户名终止相应的进程

-t:根据进程所在的终端终止相应的进程

管理员可以pkill 普通用户踢下线
普通用户不可以pkill管理员
[root@localhost ~]#pkill -9 -U “lisi”
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值