Linux使用学习笔记3 系统运维监控基础

系统运维监控类命令

查询每个进程的线程数

for pid in $(ps -ef | grep -v grep|grep "systemd" |awk '{print $2}');do echo ${pid} > /tmp/a.txt;cat /proc/${pid}/status|grep Threads > /tmp/b.txt;paste /tmp/a.txt /tmp/b.txt;done|sort -k3 -rn

for pid in $(ps -ef | grep -v grep|grep "systemd" |awk '{print $2}');do echo ${pid} > /tmp/a.txt;cat /proc/${pid}/status|grep Threads > /tmp/b.txt;paste /tmp/a.txt /tmp/b.txt;done|sort -k3 -rn

 获取$(pid)变量,也就是与systemd有关的进程的pid号,awk用于提取进程信息的pid,grep用于在文件行内匹配java字符串,grep -v grep用于排除自身带grep的进程。awk和grep都是很常见的文本处理中的命令。

下一句,echo刚刚获得的pid号,并把输出给到/tmp文件夹下的a.txt。

下一句,cat读取/proc下刚刚的pid对应的文件夹,然后进入下面的status文件读取内容,在其中寻找线程信息,并存入/tmp文件夹下的b.txt。

下一句,paste合并ab两个文件,按照列合并,中间隔一个tab.

最后对输出进行排序。按第三行,降序数字排序。

 如何检测系统中的僵尸进程将其kill

ps -e -o stat,ppid,pid,cmd |egrep '^[Zz]' 

ps -e -o stat,ppid,pid,cmd |egrep '^[Zz]' 

这里就是监测僵尸进程的命令,egrep是一个正则表达式工具,是grep命令的增强版本。现在建议使用grep -e来代替。

僵尸进程会以Z或者z开头(因为stat为z)。

这之后使用kill命令即可。但是如果要清理的进程很多,怎么办?

使用:

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

-e代表显示所有进程,-o代表按照对应格式展示,后面是要输出的列。

这里我们是杀死了父进程,为什么?因为僵尸进程已经无法被唤醒了,不能接收任何信号。所以我们利用了linux的调度机制,父进程被杀掉,僵尸进程就成了孤儿进程,孤儿进程会被交给系统1号进程,该进程会周期性的调用wait清理僵尸进程。 

如何查看占用cpu内存最多的几个进程

获取当前cpu占用最高

ps aux|head -l;ps aus|sort -rn -k3|head -10

ps aux | head -1; ps aux|sort -rn -k3|head -10

ps aux | head -1; ps aux | tail -n +2 | sort -rn -k3 | head -10

 观察输出:

 可以看到多输出了表头,让第二个ps使用tail命令从第2行开始输出就好了,这一命令对应和head类似。只不过是用来观看文章尾部。

 获取当前占用内存最高的10个进程

ps aux | head -1; ps aux|sort -rn -k4|head -10

ps aux | head -1; ps aux | tail -n +2 | sort -rn -k4 | head -10

只有排序不同。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值