简单告警系统之邮件引擎

本文索引

  • 告警系统邮件引擎
  • 运行告警系统

本文是博文《一个简单的自定义监控系统实现》的剩余部分

告警系统邮件引擎

这里使用mail.py进行邮件发送,mail.py是从网上找到的一个发送邮件的Python脚本。

#!/usr/bin/env python
#-*- coding: UTF-8 -*-
import os,sys
reload(sys)
sys.setdefaultencoding('utf8')
import getopt
import smtplib
from email.MIMEText import MIMEText
from email.MIMEMultipart import MIMEMultipart
from  subprocess import *
def sendqqmail(username,password,mailfrom,mailto,subject,content):
    gserver = 'smtp.163.com' //qq邮箱写smtp.qq.com
    gport = 25
    try:
        msg = MIMEText(unicode(content).encode('utf-8'))
        msg['from'] = mailfrom
        msg['to'] = mailto
        msg['Reply-To'] = mailfrom
        msg['Subject'] = subject
        smtp = smtplib.SMTP(gserver, gport)
        smtp.set_debuglevel(0)
        smtp.ehlo()
        smtp.login(username,password)
        smtp.sendmail(mailfrom, mailto, msg.as_string())
        smtp.close()
    except Exception,err:
        print "Send mail failed. Error: %s" % err
def main():
    to=sys.argv[1]
    subject=sys.argv[2]
    content=sys.argv[3]
##定义QQ邮箱的账号和密码,你需要修改成你自己的账号和密码(请不要把真实的用户名和密码放到网上公开,否则你会死的很惨)
    sendqqmail('1234567@qq.com','aaaaaaaaaa','1234567@qq.com',to,subject,content)
if __name__ == "__main__":
    main()

真正的mail脚本:mail.sh

#!/bin/bash
# 用来告警收敛,使得不要频繁告警
# 这里主要实现了一个计时器功能

log=$1
t_s=`date +%s`   //定义一个时间戳
t_s2=`date -d "2 hours ago" +%s`  //定义一个2小时前的时间戳
if [ ! -f /tmp/$log ]   // 判断日志是否存在,就创建;日志用来记录时间戳
then
    echo $t_s2 > /tmp/$log
fi
t_s2=`tail -1 /tmp/$log | awk '{print $1}'`  // 获取日志最后一行上的时间戳

echo $t_s>>/tmp/$log // 写入当前时间戳

v=$[$t_s-$t_s2]  // 2个时间戳时间间隔
echo $v

// 判断时间间隔是否大于1小时,符号就告警
// 这个判断是对新主机执行脚本时的判断
if [ $v -gt 3600 ]  
then
    ./mail.py  $1  $2  $3
    echo "0" > /tmp/$log.txt
else
    if [ ! -f /tmp/$log.txt ]
    then
        echo "0" > /tmp/$log.txt  // 记录告警次数,0清空数值,开始一个新的计数周期
    fi
    
    nu=`cat /tmp/$log.txt`
    nu2=$[$nu+1]
    echo $nu2 > /tmp/$log.txt
    
    if [ $nu2 -gt 10 ]  // 10钟后发告警
    then
         ./mail.py  $1 "trouble continue 10 min $2" "$3"
         echo "0" > /tmp/$log.txt  //重新计数
    fi
fi

mail.sh脚本说明

这个脚本实现的核心是计数器和计时器的功能,配合crond服务进行周期性执行,控制告警周期。

计时器代码块
log=$1
t_s=`date +%s`   
t_s2=`date -d "2 hours ago" +%s`
if [ ! -f /tmp/$log ]
then
    echo $t_s2 > /tmp/$log
fi
t_s2=`tail -1 /tmp/$log | awk '{print $1}'`
echo $t_s>>/tmp/$log
v=$[$t_s-$t_s2]
echo $v
if [ $v -gt 3600 ]  
then
    ./mail.py  $1  $2  $3
    echo "0" > /tmp/$log.txt
else
   #先不看
fi

说明的代码实现的就是计时器的功能:首先判断计时日志文件是否存在

  • 文件不存在,表示为新服务器,给予2小时前的时间戳;这样后续t_s2变量从文件内获取的时间就是新赋值的时间,时间间隔肯定大于3600,进入判断语句,立即发送告警邮件;
  • 文件存在,获取到的时间就为mail.sh执行间隔时间,这里假设为1分钟即60s,这样在进入判断时执行的就是下面的计数器代码了;
计数器代码
if [ $v -gt 3600 ]  
then
    ./mail.py  $1  $2  $3
    echo "0" > /tmp/$log.txt
else
    if [ ! -f /tmp/$log.txt ]
    then
        echo "0" > /tmp/$log.txt
    fi
    
    nu=`cat /tmp/$log.txt`
    nu2=$[$nu+1]
    echo $nu2 > /tmp/$log.txt
    
    if [ $nu2 -gt 10 ]
    then
         ./mail.py  $1 "trouble continue 10 min $2" "$3"
         echo "0" > /tmp/$log.txt 
    fi
fi
  • 第二次执行mail.sh时,此时/tmp/$log.txt应该为空,直接赋值0,开始计数,执行之后的代码值变为1;
  • 之后每次执行mail.sh,计数器值+1,当计数器值大于10,即10分钟过后,发送告警邮件,并再次清空计数器,重新计数;

运行告警系统

最终的目录结构

[root@localhost ~]# tree /usr/local/sbin/mon
/usr/local/sbin/mon
├── bin
│   └── main.sh
├── conf
│   └── mon.conf
├── log
├── mail
│   ├── mail.py
│   └── mail.sh
└── shares
    ├── 502.sh
    ├── disk.sh
    └── load.sh

编写cron计划

# 每分钟执行一次,这样告警时间间隔收敛至10分钟,这里必须进入到/usr/local/sbin/mon/bin目录下
[root@localhost ~]# crontab -e
* * * * * cd /usr/local/sbin/mon/bin; bash main.sh

转载于:https://my.oschina.net/LuCastiel/blog/1624439

课程背景 CRM(客户关系系统)一直是企业中必备的软件系统,企业通过CRM系统,可以建立与客户之间的联系,保持与客户之间良好的沟通,从而建立商机。可以说,CRM系统对于企业来讲是至关重要的。在中国,CRM系统的还没有被广泛的应用,但是在外国,CRM系统已经被很多企业所接受,应用范围十分广泛,并且也有很多成熟优秀的CRM产品。可以说,市场上对于CRM系统的需求还有很大的上升空间。本课程以一个现实的CRM系统为原型,在对系统需求分析的基础上,对系统进行了设计并且实现。由于课程时间有限,对于CRM系统的功能只实现了一部分,但是已经涵盖了全部的CRM系统的技术点。 1.2、课程内容介绍 在本课程当中,主要讲述了3个核心的知识点。第一个知识点是EasyJWeb框架,这也是国人自主研发的一款优秀的MVC框架。EasyJWeb框架是基于Velocity模板技术的,所有的页面都是静态HTML页面,省略了JSP的编译过程,大大提高了系统的访问速度。EasyJWeb对于中小型的软件项目来说是十分优秀的,内置的Action可以轻易的捕获前台的请求,而EasyJWeb提供了类似于DWR的Ajax技术,大大简化了Ajax的调用过程,提高了开发效率和运行速度。作为国内的MVC框架,EasyJWeb并没有struts2那么大的名气,但是EasyJWeb的初衷就是想要取代struts2的市场份额,在此课程中,我们也为国内自主研发的软件尽一份力量。 第二个知识点是服务调度。这个主意是针对于性能优化的方案,其核心是一种分布式的架构思想,具体的实现手段有很多种,在本课程我们使用了RMI技术来完成。通常我们会将一个完成的程序包运行在Web容器(tomcat或其他)中,容器除了要负责接受前台的请求和返回响应以外,还需要开辟大量的内存来负责数据的处理,逻辑的运算,算法的解析等。一个Web容器的内存是有限的,但是绝大多数的内存都用来处理后台的运算,那么用来接收客户请求的资源就会减少,这样就会使系统的并发数下降。为了提高系统的性能,本课程中的服务调度实际上将系统的前台和后台进行分离,Web容器只服务接收请求和返回响应,一切的数据操作和逻辑运算都交给独立的服务端运行,这样可以极大程度的提高系统的并发数。 第三个知识点是自定义邮件引擎,针对于CRM系统来说,大批量的持续发送邮件是一个很重要的功能,但是普通的邮件群发是无法完成的,邮件服务器会对邮件进行过滤和处理,为了能够尽可能的提高邮件发送的准确性,在本课程中专门讲解了一个邮件调度的功能,以邮件任务为集合,将多个邮件变成邮件任务,然后通过线程和其他的一些控制手段,提高邮件发送的准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值