系统运维监控类命令
查询每个进程的线程数
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
只有排序不同。