linux 系统监控脚本
Linux下性能預警及應急處理
自己編寫一個腳本程序,該程序在工作時段(8:00-22:00),每隔一個小時執行一次;在其他時段每隔兩小時執行一次。
每次執行都要完成如下任務:
1、檢測進程CPU占用率,如果超出30%開始預警,超出80%就把該進程取消;
2、檢測進程內存占用率,如果超出30%開始預警,超出70%就把該進程取消;
3、檢測所有磁盤分區使用情況,如果超出90%就開始預警;
4、檢測所有進程,如果發現僵尸進程,就人為取消該進程;
說明:所謂的預警就是把事件的性質、發生時間以及被處理掉的進程等重要信息統一輸出到某個日志文件中。
一、[root@Shawn-T2 ~]# crontab -e
??? 加入以下命令:? *? 8-22/1,22-7/2? *? *? *? sh? /monitor.sh
二、[root@Shawn-T2 ~]# vim monitor.sh
??? 添加以下內容:
#!/bin/bash
#This script is used for monitoring system load.
? time=`date +"%Y-%m-%d %H:%M:%S"`
? ps aux |? grep -v 'USER' >> /tmp/temp.txt
? while read -r line
? do
???? declare -i CPUUsage=`echo $line | awk '{print $3}' | awk -F. ' {print $1}'`
???? MEMUsage=`echo $line | awk '{print $4}' | awk -F. '{print $1}'`
???? ProcessNum=`echo $line | awk '{print $2}'`
???? STAT=`echo $line | awk '{print $8}'`
???? Command=`echo $line | awk ' {print $11}'`
# Monitor CPU load.
???? if [ $CPUUsage -ge 80 ];then
??????? kill -9 $ProcessNum
??????? echo "$time? Process $Command occupies too large CPU space and was killed!" >>? /var/log/monitor.log
???? elif [ $CPUUsage -ge 30 ]; then
??????? echo "$time? Process $Command occupies too large ,please check it!" >>? /var/log/monitor.log
???? fi
# Monitor Memory load.
???? if [ $MEMUsage -ge 70 ];then
??????? kill -9 $ProcessNum
??????? echo "$time? Memory $Command occupies too large memory space and was killed!" >>? /var/log/monitor.log
???? elif [ $CPUUsage -ge 30 ]; then
??????? echo "$time? Memory $Command occupies too large ,please check it!" >>? /var/log/monitor.log
???? fi
# Monitor the zombie process.
???? if [ "$STAT" == "Z" ]; then
???? kill -9 $ProcessNum
???? echo "$time Process $Command is zombie process and was killed." >>? /var/log/monotor.log
???? fi
? done < /tmp/temp.txt
? rm -f /tmp/temp.txt
#Momitor the disk partition used space.
? df | grep -v Filesystem > /tmp/temp.txt
??? while read -r line
??? do
?????? declare -i DiskUsage=`echo $line | awk '{ if(NF==6){ print $5 }? else if(NF==5) { print $4 } }'| awk -F% '{print $1}'`
?????? DirName=`echo $line | awk '{ if(NF==6){ print $6 }? else if(NF==5) { print $5 } }'| awk -F% '{print $1}'`
?????? if [ $DiskUsage -ge 90 ];then
????????? echo "$time The partitipn which the directory $DirName mounted on occupies too large space ,please check it." >> /var/log/monitor.log
?????? fi
??? done < /tmp/temp.txt
? rm -f /tmp/temp.txt
轉載于:https://blog.51cto.com/jallen/448337
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的linux 系统监控脚本的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux ssh密钥登录配置
- 下一篇: 考试能帮助我什么?