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/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • linux资料总章2.1 1.0写的不好抱歉 但是2.0已经改了很多 但是错误还是无法避免 以后资料会慢慢更新 大...
    数据革命阅读 13,032评论 2 33
  • 第1章 小试牛刀 $ 是普通用户,# 表示管理员用户 root。 shebang:#!。sharp / hash ...
    巴喬書摘阅读 6,624评论 1 4
  • Shell作为操作系统的外壳,为用户提供了使用操作系统的接口。Shell和核心是命令行提示符,它允许输入文本命令,...
    种豆瓜阅读 320评论 0 0
  • 选择的标准:使用频率非常高,几乎每天都会使用到;用了之后不想换;忍不住想跟别人推荐; 1. 好视力护眼灯 已经用了...
    小乔分享记阅读 713评论 4 4
  • 1.是什么? Gitlab-CI是GitLab Continuous Integration(Gitlab持续集成...
    优雨阅读 2,032评论 0 2

友情链接更多精彩内容