shell脚本 监控系统资源利用率cpu 内存 磁盘
shell脚本 监控系统资源利用率cpu 内存 磁盘方法1:主要功能:获取内存、cpu、磁盘利用率,当高于阈值时写入到文件中 试验了代码可以通过,在这段是网上找的,感谢网友分享(Linux 操作系统使用Shell脚本监控CPU、磁盘、内存使用率 - 腾讯云开发者社区-腾讯云)#!/bin/bash###############################################File
shell脚本 监控系统资源利用率cpu 内存 磁盘
方法一:主要功能:获取内存、cpu、磁盘利用率,当高于阈值时写入到文件中 试验了代码可以通过,在这段是网上找的,感谢网友分享
参考地址:Linux 操作系统使用Shell脚本监控CPU、磁盘、内存使用率 - 腾讯云开发者社区-腾讯云)
shell脚本:
#!/bin/bash
##############################################
#Filename: jiankong.sh
#Description: 监控cpu、磁盘、内存使用率
##############################################
logFile=jiankong.log
#获取报警时间
now_time=`date '+%F %T'`
#获取cpu使用率
cpuUsage=`top -b -n5 | fgrep "Cpu(s)" | tail -1 | awk -F'id,' '{split($1, vs, ","); v=vs[length(vs)]; sub(/\s+/, "", v);sub(/\s+/, "", v); printf "%d", 100-v;}'`
#统计内存使用率
mem_used_persent=`free -m | awk -F '[ :]+' 'NR==2{printf "%d", ($3)/$2*100}'`
#获取磁盘使用率
data_name="/dev/vda1"
diskUsage=`df -h | grep $data_name | awk -F '[ %]+' '{print $5}'`
function check(){
echo -e "CPU使用率:${cpuUsage}%\n磁盘使用率:${diskUsage}%\n内存使用率:${mem_used_persent}%"
if [[ "$cpuUsage" > 80 ]] || [[ "$diskUsage" > 80 ]] || [[ "$mem_used_persent" > 80 ]];then
echo "报警时间:${now_time}" > $logFile
echo -e "CPU使用率:${cpuUsage}% --> 磁盘使用率:${diskUsage}% --> 内存使用率:${mem_used_persent}%" >> $logFile
fi
}
function main(){
check
}
main
方法2:工作中的实际场景:需要循环写监控文件,可以设置时间间隔和需要监控的总时长
脚本:
#!/bin/bash
##############################################
#Filename: jiankong.sh
#Description: 监控cpu、磁盘、内存使用率
##############################################
logFile=jiankong.csv
#获取报警时间
now_time=`date '+%F %T'`
for count in `seq 0 40`
do
#获取cpu使用率
cpuUsage=`top -b -n5 | fgrep "Cpu(s)" | tail -1 | awk -F'id,' '{split($1, vs, ","); v=vs[length(vs)]; sub(/\s+/, "", v);sub(/\s+/, "", v); printf "%d", 100-v;}'`
#统计内存使用率
mem_used_persent=`free -m | awk -F '[ :]+' 'NR==2{printf "%d", ($3)/$2*100}'`
#获取磁盘使用率
data_name="/dev/vda1"
diskUsage=`df -h | grep $data_name | awk -F '[ %]+' '{print $5}'`
time=`date +%Y%m%d%H%M`
# echo -e "时间:${time}, CPU使用率: ${cpuUsage}% , 磁盘使用率:${diskUsage}%, 内存使用率:${mem_used_persent}%" >> $logFile
echo -e "${time},${cpuUsage}%,${mem_used_persent}%" >> $logFile
sleep 5
done
更多推荐
所有评论(0)