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 发邮件的更多相关文章

  1. Linux性能监控

    转自:http://blog.csdn.net/chosen0ne/article/details/8200737 linux性能监控,就是要监控系统的各个子系统是否正常.linux主要的子系统包括: ...

  2. Linux 性能监控之CPU&内存&I/O监控Shell脚本2

    Linux 性能监控之CPU&内存&I/O监控Shell脚本2   by:授客 QQ:1033553122 思路: 捕获数据->停止捕获数据->提取数据 备注:一些命令的输 ...

  3. Linux 性能监控之CPU&内存&I/O监控Shell脚本1

    Linux 性能监控之CPU&内存&I/O监控Shell脚本1   by:授客 QQ:1033553122   #!/bin/bash # 获取要监控的本地服务器IP地址 IP=`if ...

  4. linux性能监控 -CPU、Memory、IO、Network等指标的讲解

    [操作系统-linux]linux性能监控 -CPU.Memory.IO.Network等指标的讲解(转) 一.CPU 1.良好状态指标 CPU利用率:User Time <= 70%,Syst ...

  5. Linux性能监控与分析之--- CPU

    Linux性能监控与分析之--- CPU 望月成三人关注 2016.07.25 18:16:12字数 1,576阅读 2,837 CPU性能指标 用户进程使用CPU的比率 系统进程使用CPU的比率 W ...

  6. Linux 性能监控的18个命令行工具

    对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐 认识到监控和保持系统启动并运行是多么的不容易.基于此原因,我 ...

  7. linux安装配置sendmail实现邮件发送

    sendmail配置 yum -y update sendmail sendmail-cf SendMail相关目录1. 设定档目录:/etc/mail2. 记录档:/var/log/maillog3 ...

  8. Linux 性能监控、测试、优化工具

    Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg 在最近的 LinuxCon NA 2014 ...

  9. 三张图看遍Linux 性能监控、测试、优化工具

    Linux 平台上的性能工具有很多,眼花缭乱,长期的摸索和经验发现最好用的还是那些久经考验的.简单的小工具.系统性能专家 Brendan D. Gregg 在最近的 LinuxCon NA 2014 ...

随机推荐

  1. visio的形状默认是蓝色的填充色,怎么设置为白色为默认色?

    如图所示: 设计->主题->选黑白那个 效果如下:

  2. 1.python环境安装

    一:安装Python与环境配置 二:安装pip 三:Anaconda安装和使用 3.1 什么是 Anaconda? Anaconda是专注于数据分析的Python发行版本,支持 Linux, Mac, ...

  3. 3.Minst数据集分类

    import numpy as np from keras.datasets import mnist from keras.utils import np_utils from keras.mode ...

  4. CSS基础学习-12.CSS position

    绝对定位 position:absolute,元素脱离文档流,然后使用left.right.top.bottom属性相对于其最接近的一个具有定位属性的祖先元素进行绝对定位.如果不存在这样的祖先元素,则 ...

  5. Tomcat基础知识

    介绍Tomcat之前先介绍下Java相关的知识. 各常见组件: 1.服务器(server):Tomcat的一个实例,通常一个JVM只能包含一个Tomcat实例:因此,一台物理服务器上可以在启动多个JV ...

  6. js中for..of..和迭代器

    for..of是ES6中引入的新特性,它主要的作用是:循环一个可迭代的对象. 它可以循环遍历,数组.字符串.Set对象等等 示例一: let str = 'hello' for (item of st ...

  7. 题解 【POJ1157】LITTLE SHOP OF FLOWERS

    先把题目意思说一下: 你有F束花,编号为\(1\)~\(F\)(\(1<=F<=100\)),\(V\)个花瓶,编号为\(1\) ~\(V\)(\(1<=V<=100\)), ...

  8. hdu 6096 String

    题 OvO http://acm.hdu.edu.cn/showproblem.php?pid=6096 ( 2017 Multi-University Training Contest - Team ...

  9. C# 多线程任务分配辅助类

    1)首先实现一个多线程的辅助类,代码如下: public class ThreadMulti { public delegate void DelegateComplete(); public del ...

  10. [CTF]Heap vuln -- unlink

    0x00: 起因 一直在堆的漏洞利用中不得要领,之前ZCTF又是三个堆的利用,血崩,chxx表哥给写了一个heap的pwn,学习学习. 0x01: 关于heap的unlink的漏洞利用,出的很早,在低 ...