监控磁盘使用率的shell脚本

简介:

本脚本来自有学习阿铭的博文学习:
公司监控最基本的一般都要监控磁盘的使用情况,否则将导致业务上的事故。
一般监控要求如下:每分钟都要扫描一下磁盘的状况。
当磁盘空间使用率或者inode使用率高于90%的情况,就需要报警。
并把统计使用率超过90%的分区的所有的子目录的,按照大小依次排列,把前3的目录名称发给到邮箱。
第一次未处理,30分钟后在一次。

#!/bin/bash
#用途:监控磁盘的使用情况。
#作者:Caron maktini
#日期:2018年10月18日
#版本:v0.1
#把脚本名字存在变量l-name
l_name=`echo $0 | awk -F '/' 'print $NF'`
#定义收件人的邮箱
mail_user=admin@admin.com

#定义检查磁盘的空间使用率函数
chk_sp()
{
    df -m | sed '1d' | awk -F '% | +' '$5>90 {print $7,$5}'>/tmp/chk_sp.log
    n=`wc -l /tmp/chk_sp.log | awk 'print $1'`
    if [ $n -gt 0 ]
    then 
      tag=1
      for d in `awk '{print $1}' /tmp/chk_sp.log`
      do 
           find $d -type d | sed '1d' | xargs du -sm | sort -nr | head -3
      done >/tmp/most_sp.txt
   fi
               
}

#定义检查inode使用率函数

chk_in()
{
  df -i | sed `1d` | awk -F '% | +' '$5>90 {print $7,$5}'>/tmp/chk_in.log
    n=`wc -l /tmp/chk_in.log | awk '{print $1}'`
    if [ $n -gt 0 ]
    then 
        tag=2
    fi
 }

#定义告警函数

m_mail(){
    log=$1
    t_s=`date +%s`
    t_s2=`data -d "1 hours ago" +%s`
    if [ ! -f /tmp/$log ]
    then
        #创建$log文件
        touch /tmp/$log
        #增加a权限,只允许追加内容,不允许更改或删除
        chattr +a /tmp/$log
        #第一次告警,可以直接写入1小时以前的时间戳
        echo $t_s2 >> /tmp/$log
     fi
    #无论#log文件是否刚刚创建,都需要查看最后一行的时间戳
    t_s2=`tail -l /tmp/$log | awk '{print $1}'`
    # 取出最后一行及上次告警的时间戳,立即写入当期的时间戳
    echo $t_s >>/tmp/$log
    #取两次时间戳差值
    v=$[ $t_s-$t_s2 ]
    #如果差值超过100,立即发送邮件。
    if [ $v -gt 1800 ]
    then
      #发邮件,其中$2为mail函数的第二个函数,这里为一个文件
      python  mail.py $mail_user "磁盘使用率超过90%"
      #定义技数器临时文件,并写入0
      echo "0" > /tmp/$log.count
     else
      #如果技数器临时文件不存在,需要创建并写入0
      if [ ! -f /tmp/$log.count }
      then
         echo "0" > /tmp/$log.count 

      fi

      nu=`cat /tmp/$log.count`
      #30分钟内每发生1次告警,计算器加1
      nu2=$[ $nu+1 ]
      echo $nu2>/tmp/$log.count
      #当告警次数超过30次,需要再次发油件
      if [ $nu2 -gt 30 ]
      then 
          python mail.py $mail_user "磁盘使用率90%持续30分钟了" "`cat $2`" 2>/dev/null
          #第二次告警后,将计算器再次从0开始
          echo "0" > /tmp/$log.count
      fi
 fi 
}
#把进程数大于0.则说明上次的脚本还未执行完
if [ $p_n -gt 0 ]
then
    exit

fi
 

chk_sp
chk_in

if [ $tag == 1 ]
then
    m_mail chk_sp /tmp/most_sp.txt
elif [ $tag == 2 ]
then
    m_mail chk_in /tmp/chk_in.log
fi 
相关文章
|
20天前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
58 1
|
6天前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
22 2
6种方法打造出色的Shell脚本
|
11天前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
36 6
|
7天前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
1月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
60 12
|
1月前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
37 2
|
29天前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
20 0
|
监控 Shell Linux
linux实现shell脚本监控磁盘内存达到阈值时清理catalina.out日志
linux实现shell脚本监控磁盘内存达到阈值时清理catalina.out日志
292 0
|
监控 Shell
shell脚本写出监控内存,磁盘使用率的脚本,超过阈值,用“wall”命令发警报
shell脚本写出监控内存,磁盘使用率的脚本,超过阈值,用“wall”命令发警报
189 0