linux shell 指定cpu,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

详解

将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/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值