linux性能监控 + Sendmail 发邮件
#!/bin/bash
#控制发邮件的阈值是在rate,rate1和FF值(三个同样的用途,仅仅是名字不同)
#
#注:该博文中的变量不规范,我是随意定义的,请注意
#
#定义时间倒计时函数
stop_time(){
kk=3
while [ $kk -gt 0 ];do
sleep 1
kk=$(($kk - 1))
echo -ne "\r \r"
done
}
#free 监控内存使用率,超过80%就发邮件
#获取当前内存各值
mem_total=$(free -m | sed -n '2p' | awk '{print $2}')
mem_used=$(free -m | sed -n '2p' | awk '{print $3}')
mem_free=$(free -m | sed -n '2p' | awk '{print $4}')
mem_shared=$(free -m | sed -n '2p' | awk '{print $5}')
mem_buff=$(free -m | sed -n '2p' | awk '{print $6}')
mem_cached=$(free -m | sed -n '2p' | awk '{print $7}')
mem_rate=`echo "scale=2;$mem_used/$mem_total" | bc | awk -F. '{print $2}'`
[ ! -d /home/zpz/mail ] && mkdir /home/zpz/mail
echo "10分钟前内存使用情况:">>/home/zpz/mail/memory.txt
#换算成M和G为单位
echo -e "total: `expr $mem_total / 1000`G (${mem_total}M)
used: `expr $mem_used / 1000`G (${mem_used}M)
free: `expr $mem_free / 1000`G (${mem_free}M)
shared: `expr $mem_shared / 1000`G (${mem_shared}M)
buffer: `expr $mem_buff / 1000`G (${mem_buff}M)
available: `expr $mem_cached / 1000`G (${mem_cached}M)">>/home/zpz/mail/memory.txt
echo -e "rate:${mem_rate}%(如显示为 06% 即表示 0.06%,换算成G为单位时均以1000计算,而非1024)">>/home/zpz/mail/memory.txt
if [ $mem_rate -ge 40 ];then
stop_time
mem_total1=$(free -m | sed -n '2p' | awk '{print $2}')
mem_used1=$(free -m | sed -n '2p' | awk '{print $3}')
mem_rate1=`echo "scale=2;$mem_used1/$mem_total1" | bc | awk -F. '{print $2}'`
#判断2次统计的内存使用率
if [ $mem_rate1 -ge $mem_rate ];then
echo "">>/home/zpz/mail/memory.txt
echo "当前内存使用情况:">>/home/zpz/mail/memory.txt
echo -e "total: `expr $mem_total / 1000`G (${mem_total}M)
used: `expr $mem_used / 1000`G (${mem_used}M)
free: `expr $mem_free / 1000`G (${mem_free}M)
shared: `expr $mem_shared / 1000`G (${mem_shared}M)
buffer: `expr $mem_buff / 1000`G (${mem_buff}M)
available: `expr $mem_cached / 1000`G (${mem_cached}M)">>/home/zpz/mail/memory.txt
echo "rate:${mem_rate}%(换算成G为单位时均以1000计算,而非1024)">>/home/zpz/mail/memory.txt
fi
else
#如果以上条件都不成立就将memory.txt文件清零并将各变量赋空值
mem_opop=" "
mem_kk=" "
fi
#监控磁盘使用率,超过80%就发邮件
DEV=`df -hP | grep '^/dev/*' | awk -F ' ' '{print $1}'|sort`
for i in $DEV
do
disk_dev=`df -Ph | grep $i | awk '{print $1}'`
disk_size=`df -Ph | grep $i | awk '{print $2}'`
disk_used=`df -Ph | grep $i | awk '{print $3}'`
disk_free=`df -Ph | grep $i | awk '{print $4}'`
disk_rate=`df -Ph | grep $i | awk '{print $5}'`
disk_mount=`df -Ph| grep $i | awk '{print $6}'`
#定义磁盘利用率
disk_F=`echo $disk_rate | awk -F% '{print $1}'`
if [ $disk_F -ge 40 ];then
echo " ">>/home/zpz/mail/memory.txt
echo " ">>/home/zpz/mail/memory.txt
echo "10分钟前硬盘使用率: $disk_rate">>/home/zpz/mail/memory.txt
for p in $DEV;do echo -e "$p:\tsize:$disk_size\tused:$disk_used\tfree:$disk_free\tmount: $disk_mount";done>>/home/zpz/mail/memory.txt
stop_time
disk_dev1=`df -Ph | grep $i | awk '{print $1}'`
disk_size1=`df -Ph | grep $i | awk '{print $2}'`
disk_used1=`df -Ph | grep $i | awk '{print $3}'`
disk_free1=`df -Ph | grep $i | awk '{print $4}'`
disk_rate1=`df -Ph | grep $i | awk '{print $5}'`
disk_mount1=`df -Ph | grep $i | awk '{print $6}'`
disk_FF=`echo $disk_rate1 | awk -F% '{print $1}'`
#判断2次统计的硬盘使用率
if [ $disk_FF -ge $disk_F ];then
echo " ">>/home/zpz/mail/memory.txt
echo "当前硬盘使用率: $disk_rate1">>/home/zpz/mail/memory.txt
for H in $DEV;do echo -e "$H:\tsize:$disk_size1\tused:$disk_used1\tfree:$disk_free1\tmount: $disk_mount1";done >>/home/zpz/mail/memory.txt
else
echo " ">/home/zpz/mail/memory.txt
fi
fi
done
if [[ $mem_rate1 -ge 70 || $disk_FF -ge 80 ]];then
mail -v -s "44服务器的硬盘警告" xxxxx@126.com</home/zpz/mail/memory.txt
echo " ">/home/zpz/mail/memory.txt
fi
QQ群: 欢迎你的加入
该文章为原创,转载请注明原出处 谢谢合作
linux性能监控 + Sendmail 发邮件的更多相关文章
- Linux性能监控
转自:http://blog.csdn.net/chosen0ne/article/details/8200737 linux性能监控,就是要监控系统的各个子系统是否正常.linux主要的子系统包括: ...
- Linux 性能监控之CPU&内存&I/O监控Shell脚本2
Linux 性能监控之CPU&内存&I/O监控Shell脚本2 by:授客 QQ:1033553122 思路: 捕获数据->停止捕获数据->提取数据 备注:一些命令的输 ...
- Linux 性能监控之CPU&内存&I/O监控Shell脚本1
Linux 性能监控之CPU&内存&I/O监控Shell脚本1 by:授客 QQ:1033553122 #!/bin/bash # 获取要监控的本地服务器IP地址 IP=`if ...
- linux性能监控 -CPU、Memory、IO、Network等指标的讲解
[操作系统-linux]linux性能监控 -CPU.Memory.IO.Network等指标的讲解(转) 一.CPU 1.良好状态指标 CPU利用率:User Time <= 70%,Syst ...
- Linux性能监控与分析之--- CPU
Linux性能监控与分析之--- CPU 望月成三人关注 2016.07.25 18:16:12字数 1,576阅读 2,837 CPU性能指标 用户进程使用CPU的比率 系统进程使用CPU的比率 W ...
- Linux 性能监控的18个命令行工具
对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐 认识到监控和保持系统启动并运行是多么的不容易.基于此原因,我 ...
- linux安装配置sendmail实现邮件发送
sendmail配置 yum -y update sendmail sendmail-cf SendMail相关目录1. 设定档目录:/etc/mail2. 记录档:/var/log/maillog3 ...
- Linux 性能监控、测试、优化工具
Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg 在最近的 LinuxCon NA 2014 ...
- 三张图看遍Linux 性能监控、测试、优化工具
Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg 在最近的 LinuxCon NA 2014 ...
随机推荐
- visio的形状默认是蓝色的填充色,怎么设置为白色为默认色?
如图所示: 设计->主题->选黑白那个 效果如下:
- 1.python环境安装
一:安装Python与环境配置 二:安装pip 三:Anaconda安装和使用 3.1 什么是 Anaconda? Anaconda是专注于数据分析的Python发行版本,支持 Linux, Mac, ...
- 3.Minst数据集分类
import numpy as np from keras.datasets import mnist from keras.utils import np_utils from keras.mode ...
- CSS基础学习-12.CSS position
绝对定位 position:absolute,元素脱离文档流,然后使用left.right.top.bottom属性相对于其最接近的一个具有定位属性的祖先元素进行绝对定位.如果不存在这样的祖先元素,则 ...
- Tomcat基础知识
介绍Tomcat之前先介绍下Java相关的知识. 各常见组件: 1.服务器(server):Tomcat的一个实例,通常一个JVM只能包含一个Tomcat实例:因此,一台物理服务器上可以在启动多个JV ...
- js中for..of..和迭代器
for..of是ES6中引入的新特性,它主要的作用是:循环一个可迭代的对象. 它可以循环遍历,数组.字符串.Set对象等等 示例一: let str = 'hello' for (item of st ...
- 题解 【POJ1157】LITTLE SHOP OF FLOWERS
先把题目意思说一下: 你有F束花,编号为\(1\)~\(F\)(\(1<=F<=100\)),\(V\)个花瓶,编号为\(1\) ~\(V\)(\(1<=V<=100\)), ...
- hdu 6096 String
题 OvO http://acm.hdu.edu.cn/showproblem.php?pid=6096 ( 2017 Multi-University Training Contest - Team ...
- C# 多线程任务分配辅助类
1)首先实现一个多线程的辅助类,代码如下: public class ThreadMulti { public delegate void DelegateComplete(); public del ...
- [CTF]Heap vuln -- unlink
0x00: 起因 一直在堆的漏洞利用中不得要领,之前ZCTF又是三个堆的利用,血崩,chxx表哥给写了一个heap的pwn,学习学习. 0x01: 关于heap的unlink的漏洞利用,出的很早,在低 ...