简单错误日志报警-(定时版本)

7 篇文章 0 订阅
4 篇文章 0 订阅

sendEmail-v1.56.tar.gz 下载地址:
链接:https://pan.baidu.com/s/1FS5sQbULtMyp0wNVfZpJTQ 
提取码:set3 


编写脚本1

vi timer_logerr_monitor.sh


代码:粘贴进入

#!/bin/sh
SYSTEMNAME=XXX系统
LINENUM=500
ERROR_LOG=`/bin/ls /data/logs/log_error.log`
DATE=`date +%Y年%m月%d日%H时%M分%S秒`
ERROR_NEW_LOG=/data/logs/$DATE'_error.log'
HOST=`/bin/hostname`
IP=`/sbin/ifconfig|grep "inet addr"|grep "Bcast"|cut -d":" -f2|awk -F" " '{print $1}'`
 
if [ ! -f $ERROR_NEW_LOG ];then
/bin/touch $ERROR_NEW_LOG
fi
echo '-------1-----' 
NUM1=$(/usr/bin/tail -$LINENUM $ERROR_LOG|grep 'Exception'|grep -v '不存在'|grep -v '资源'|grep -v '验证码'|grep -v '邀请'|grep -v '用户'|grep -v '账号'|grep -v 'HttpRequestMethodNotSupportedException'|wc -l)
NUM2=$(/bin/cat $ERROR_NEW_LOG|wc -l)

if [ -f $ERROR_LOG ] && [ $NUM1 -ne 0 ] && [ $NUM2 -eq 0 ];then
/usr/bin/tail -1000 $ERROR_LOG  > $ERROR_NEW_LOG
ERROR_MESSAGE=$(cat $ERROR_NEW_LOG)

rm -rf $ERROR_LOG

/bin/touch $ERROR_LOG

/bin/bash /xxx/sendemail.sh xxxx@163.com "${SYSTEMNAME}${HOSTNAME}机器的log_err.log日志中的error监控" "告警主机:${HOSTNAME} \n告警IP:${IP} \n告警时间:${DATE} \n告警等级:严重,抓紧解决啊!  \n告警详情:log_err.log日志中出现error了! \n告警日志文件:${ERROR_LOG} \n错误信息: \n ${ERROR_MESSAGE} "
fi


编写脚本2

vi sendemail.sh


代码:粘贴进入

# Filename: SendEmail.sh
# Notes: 使用sendEmail
#
# 脚本的日志文件
echo '-------start---email-----------------'
LOGFILE="/tmp/Email.log"
:>"$LOGFILE"
exec 1>"$LOGFILE"
exec 2>&1
#开通邮箱得SMTP_server
SMTP_server='smtp.163.com'
username='xxxx@163.com'
password='xxxx'
from_email_address='yyyyy@163.com'
to_email_address1="yyyyy@xdf.cn"
message_subject_utf8="$2"
message_body_utf8="$3"
# 转换邮件标题为GB2312,解决邮件标题含有中文,收到邮件显示乱码的问题。
message_subject_gb2312=`iconv -t GB2312 -f UTF-8 << EOF
$message_subject_utf8
EOF`
[ $? -eq 0 ] && message_subject="$message_subject_gb2312" || message_subject="$message_subject_utf8"
# 转换邮件内容为GB2312,解决收到邮件内容乱码
message_body_gb2312=`iconv -t GB2312 -f UTF-8 << EOF
$message_body_utf8
EOF`
[ $? -eq 0 ] && message_body="$message_body_gb2312" || message_body="$message_body_utf8"
# 发送邮件
#sendEmail-v1.56 下载解压
sendEmail='/xxx/sendEmail-v1.56/sendEmail'
set -x
$sendEmail -s "$SMTP_server" -xu "$username" -xp "$password" -f "$from_email_address" -t "$to_email_address1" -u "$message_subject" -m "$message_body" -o message-content-type=text -o message-charset=gb2312

编写Linux定时任务crontab,不会编辑crontab可以看https://blog.csdn.net/hymas/article/details/112977837
加入

45 *   * * *   root    sh /xxxx/timer_logerr_monitor.sh >/dev/null 2>&1


每小时45分循环一次

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值