脚本监控重要文件,并邮箱报警

#! /usr/bin/bash

#==================================================
#                     脚本说明  
#    使用前请先自行配置mail配置文件/etc/mail.rc
#    文件末尾添加
#    set from=发送邮箱
#    set smtp=smtp.163.com
#    set smtp-auth-user=接收邮箱
#    set smtp-auth-password=密码或者授权码
#    set smtp-auth=login
#    并修改文中"自己报警接收邮箱"为自己邮箱号
#==================================================

haxi(){
file1="/etc/passwd /etc/hosts /etc/rc.d/rc.local"  
                                                 # 重要文件绝对路径赋值给变量
md5sum $file1 > /root/bb.txt                     # 做出哈希值并记录
md5sum -c /root/bb.txt &> /dev/null              # 将记录的哈希值锁定
}  

panduan(){
    md5sum -c /root/bb.txt | grep "FAILED"       # 锁定哈希值,并且过滤出改变过的
    if [ $? -eq 0 ];then                         # 判断过滤哈希值这一步是否成功完成
    warin                                        # 如果过滤出来,则执行
    else        
    success "持续监控中"                          # 否则继续监控
    fi
 }

warin(){
wj=`md5sum -c /root/bb.txt | grep "FAILED"`       # 将哈希值有变化的文件赋值给变量
cat >> aa.txt << EOF                               
$wj
EOF
                                                    # 输入重定向 将哈希值有变化的文件名称到aa.txt文件
cat aa.txt | mail -s "报警提示" 自己报警接收邮箱     # 查看aa.txt文件内容,并发送邮件
error "重要文件已经被修改,请查看邮箱"                #屏幕提示
haxi                                                # 运行此函数,重新做出哈希值,继续监控

}

haxi
while :
do
    panduan
    sleep 60

done


error(){
    echo -e "\e[31m[`date '+%H:%M:%S'`]$@\e[0m"
    sleep 0.5
}

warning(){
    echo -e "\e[33m[`date '+%H:%M:%S'`]$@\e[0m"
    sleep 0.5
}

success(){
    echo -e "\e[32m[`date '+%H:%M:%S'`]$@\e[0m"
    sleep 0.5
}

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值