Linux 負載監控腳本

#!/bin/bashbash

Date=`echo $(date +%Y\-%m\-%d\ %H:%M:%S)`
HostName=`hostname`
IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`
ServerInfo=`echo -e "--------$Date--------\n服務器:$HostName IP:$IP"`服務器

#刪除5天前的監控日誌
LOGPWD=/var/log/monitor
LOGDATE=`echo $(date -d -5day +%Y%m%d)`
LOGGREP=`ls $LOGPWD | grep -c "$LOGDATE"`
if [ $LOGGREP -gt 0 ]
then
rm -fr $LOGPWD/*$LOGDATE.log
fiui

echo -e "$ServerInfo\nuptime\n`uptime`\nfree -m\n`free -m`" > $LOGPWD/monitor.log
#監控cpu負載
PhysicalCpu=`grep 'physical id' /proc/cpuinfo | sort -u | wc -l`
CoreCpu=`grep 'core id' /proc/cpuinfo | sort -u | wc -l`
count_cores=`echo "$PhysicalCpu*$CoreCpu" | bc`
count_uptime=`uptime |wc -w`
AverageLoad=`uptime | awk '{print $'$count_uptime'}'`
AverageInt=`echo $AverageLoad | cut -f 1 -d "."`
if [ $AverageInt -gt $count_cores ]
then
echo -e "$ServerInfo\n15分鐘的負載爲$AverageLoad,核心數$count_cores,超過cpu核心數,請處理!" >> $LOGPWD/cpu_status_$(date +%Y%m%d).log
echo -e "15分鐘的負載爲$AverageLoad,核心數$count_cores,超過cpu核心數,請處理!" >> $LOGPWD/monitor.log
else
echo -e "$ServerInfo\n15分鐘的負載爲$AverageLoad,核心數$count_cores,負載正常。" >> $LOGPWD/cpu_status_$(date +%Y%m%d).log
echo -e "15分鐘的負載爲$AverageLoad,核心數$count_cores,負載正常。" >> $LOGPWD/monitor.log
fi
#監控內存使用率
MemTotal=`free -m | grep Mem | awk '{print $2}'`
MemFree=`free -m | grep Mem | awk '{print $4}'`
MemRate=`echo "100-$MemFree*100/$MemTotal" | bc`
if [ $MemRate -gt 80 ]
then
echo -e "$ServerInfo\n內存使用率$MemRate%,大於80%,請處理。" >> $LOGPWD/mem_status_$(date +%Y%m%d).log
echo -e "內存使用率$MemRate%,大於80%,請處理。" >> $LOGPWD/monitor.log
else
echo -e "$ServerInfo\n內存使用率$MemRate%,小於等於80%,內存負載正常。" >> $LOGPWD/mem_status_$(date +%Y%m%d).log
echo -e "內存使用率$MemRate%,小於等於80%,內存負載正常。" >> $LOGPWD/monitor.log
fi日誌

if [ $AverageInt -gt $count_cores ]||[ $MemRate -gt 80 ]
then
cat $LOGPWD/monitor.log | mail -s "$HostName服務器負載監控報警"xxx@xxx.xxx
fi內存

相關文章
相關標籤/搜索