Linux 第三课 Shell 脚本-可用CPU

作业:
编写脚本,判断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 

详解

  1. 将Top 的信息 写入到 指定文件 top.log 中
  2. 因获取的free_cpu 带有" %id," 因此 用sed 进行了替换
  3. 因free_cpu 为浮点数 ,在算可用CPU 使用了 bc
  4. 当free_cpu小于20时,对top.log中所有CPU进行排序,得到最大的CPU的 cpu值、PID、进程名

考查点

  1. awk (awk '{print $9,$1,$12}' 表示输出第9列,第1列,第12列)
  2. sed
  3. 浮点数处理
  4. sort 排序
  5. head 获取行数
  6. 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/

你可能感兴趣的:(Linux 第三课 Shell 脚本-可用CPU)