杀死僵尸进程,需要这些神奇高效的 Linux 命令

一、五大系统运维状态

对运维来说,查看系统运行状态是最基础的工作之一。
要了解CPU、内存、进程、磁盘、网络,这五大运维系统的运行状态,需要掌握的运维命令有ls、ps、free、top、uptime、ifconfig、su/sudo、dmesg、iostat、vmstat、sar、htop、iotop、smem等命令。

二、内存状态检测工具

要安装 smem 这个工具,需要在系统上安装EPEL软件源,安装过程如下:

[root@localhost ~]# yum -y install epel-release
[root@localhost ~]# yum -y install smem python-matplotlib python-tk

要显示系统中每个进程的占用内存状态,可执行如下图指令(smem -k -s uss):
在这里插入图片描述
上图中,"-k"参数用来显示内存单位,"-s"是排序,uss是对uss列进行排序,这样,就输出了系统中所有进行占用的内存大小,非常清晰明白。
smem还支持以百分比形式显示每个进程占用系统内存的比率(smem -p -s uss),如下图所示:
在这里插入图片描述
其中,"-p"表示以百分比的形式报告内存使用情况,这样每个进程占用的系统内存比重一目了然。
smem还可以显示系统中每一个用户的内存使用情况(smem -u -k),如下图所示:
在这里插入图片描述
其中,"-u"表示显示用户占用内存信息。
最后,smem还支持查看某个进程占用内存大小,例如:

smem -P nginx
smem -k -P nginx

由此可知,通过smem,对每个进程占用的内存资源可以很轻松的获取。

三、CPU/内存占用进程

这个应用需求在服务器的问题排查和故障处理上使用率非常高,要获取这些信息,只需要一些命令组合即可实现,可以说非常简单。
首先,获取当前系统占用CPU最高的前10个进程最简单的方式是通过ps命令组合实现,例如:

[root@localhost ~]# ps aux | head -1
[root@localhost ~]# ps aux | sort -rn -k3 | head -10

其中,第一句主要是为了获取标题(USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND)信息。而"head:-N"可以指定显示的行数,默认显示10行。

第二个命令是一个输出加排序组合,ps参数的a指代all,表示所有的进程,u指代user id,就是执行该进程的用户id,x指代显示所有程序,不以终端机来区分。

接下来是sort命令,其中:r指代reverse,这里是指反向比较结果,输出时默认从小到大,反向后从大到小。n指代numberic sort,根据其数值排序。k代表根据哪一列进行排序,后面的数字3表示按照第3列排序。本例中,可以看到%CPU在第3个位置,因此k3表示根据%CPU的数值进行由大到小的排序。

接下来的"|"为管道符号,将查询出的结果导到下面的命令中进行下一步的操作。

最后的"head -10"命令获取默认前10行数据。

四、清除僵尸过程

一个僵尸进程产生的过程是:父进程调用 fork 创建子进程后,子进程运行直至其终止,它立即从内存中移除,但进程描述符仍然保留在内存中。
要查找系统中的僵尸进程,有多种方法,这里给出一种命令行探测僵尸进程的方法:

[root@localhost ~]# ps -e -o stat,ppid,pid,cmd | egrep '^[Zz]'Z 10808 10812 [java]

参数说明:
-e:参数用于列出所有的进程
-o:参数用于设定输出格式,这里只输出进程的stat(状态信息)、ppid(父进程pid)、pid(当前进程的pid),cmd(即进程的可执行文件)。
egrep:是linux下的正则表达式工具
'[Zz]’:这是正则表达式,表示第一个字符的位置,[Zz],表示小写z或者大写的Z字母,即表示第一个字符为Z或者z开头的进程数据,只所以这样是因为僵尸进程的状态信息以Z或者z字母开头。

找到僵尸进程的pid后,直接通过"kill -9 pid"命令杀掉即可,但是如果僵尸进程很多的话,就会很繁琐,因此,还需要一个批量删除僵尸进程的办法:

[root@localhost ~]# ps -e -o stat,ppid,pid,cmd | grep -e '^[Zz]' | awk '{print $2}' | xargs kill -9

这是个命令组合,通过管道实现命令的组合应用。

"grep -e"相当于egrep命令。
"awk ‘{print $2}’ "是将前面命令的输出信息进行过滤,仅仅输出第二列的值,而第二列就是进程的ppid。
"xargs kill -9"这是将得到的ppid传给"kill -9"作为参数,也就是kill掉这些ppid。xargs命令可以将标准输入转成各种格式化的参数,这里是将管道的输出内容作为参数传递给kill命令。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值