作业:
编写脚本,判断cpu可用小于20则给出告警,并列出当前占用cpu最大的那个进程id,进程cpu,进程名
#!/bin/bash
result_file=top.log
baseline_cpu=20
filter_string="print \$9,\$1,\$12"
top -b -n 1 > $result_file
free_cpu=`grep Cpu $result_file | awk '{print $5}' | sed "s|\%\([a-z]\)\([a-z]\)\,||g"`
used_cpu=`echo 100 - $free_cpu | bc`
echo "free cpu: $free_cpu , used_cpu: $used_cpu"
echo
if [ $(echo "$free_cpu > $baseline_cpu "|bc) -eq 1 ];then
echo "idle cpu is enough"
else
echo "cpu is not enough , max used cpu pid info : "
echo
echo "cpu pid cmd"
echo "`grep %CPU -A 100000 $result_file | grep -v %CPU | awk '{print $9,$1,$12}' | sort -nrk1 | head -n 1 ` "
fi
详解
- 将Top 的信息 写入到 指定文件 top.log 中
- 因获取的free_cpu 带有" %id," 因此 用sed 进行了替换
- 因free_cpu 为浮点数 ,在算可用CPU 使用了 bc
- 当free_cpu小于20时,对top.log中所有CPU进行排序,得到最大的CPU的 cpu值、PID、进程名
考查点
- awk (awk '{print $9,$1,$12}' 表示输出第9列,第1列,第12列)
- sed
- 浮点数处理
- sort 排序
- head 获取行数
- grep
补充:
grep 的 -A -B -C 后面都跟阿拉伯数字。
-A是显示匹配后和它后面的n行
-B是显示匹配行和它前面的n行
-C是匹配行和它前后各n行
-v指不显示包含xxx的行或文件,-v表示取反
练习head
在/root目录下查找大于2M的以test开头的文件,并对第一个文件建立硬链接文件/root/chancestest/log
ln `find /root -type f -name "test*" -a -size +2M | head -n 1` /root/chancestest/log/