#!/usr/bin/env python
#coding:utf8
import re
import os
import time
import smtplib
import socket
import fcntl
import struct
from email.mime.text import MIMEText
def get_ip_address(ifname):
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
return socket.inet_ntoa(fcntl.ioctl(
s.fileno(),
0x8915, # SIOCGIFADDR
struct.pack('256s', ifname[:15])
)[20:24])
def sendemail(subject,msg,fromemail,emailpasswd,toemail):
'''实现发送邮件功能函数'''
_user = fromemail
_pwd = emailpasswd
_to = toemail
nowtime = time.strftime('%Y-%m-%d %H:%M:%S')
msg = MIMEText(msg)
msg["Subject"] = subject
msg["From"] = _user
msg["To"] = _to
try:
s = smtplib.SMTP_SSL('smtp.qq.com', 465)
s.login(_user, _pwd)
s.sendmail(_user, _to, msg.as_string())
s.quit()
print "[%s]INFO:Email send Success!" % nowtime
except smtplib.SMTPException,e:
print "[%s]ERROR:Email send Falied,%s" % (nowtime,e)
def matchkeyword(pattern,alertlogfile):
'''实现匹配关键字函数'''
re.compile(pattern)
posfile = "/tmp/posfile"
if not os.path.exists(posfile):
os.mknod(posfile)
if not os.path.getsize(posfile):
with open(posfile,'w') as fobj:
fobj.write('0')
#打开文件
f = open(alertlogfile,'r')
#移动到文件结尾
f.seek(0,2)
#读出文件所在的字节位置
endpos = f.tell()
#移动到文件的开头
with open(posfile,'r') as fobj:
startpos = int(fobj.read())
f.seek(startpos)
if endpos-startpos > 0:
data = f.read(endpos-startpos)
f.close()
with open(posfile,'w') as fobj:
fobj.write(str(endpos))
m = re.findall(pattern, data,re.IGNORECASE)
if m:
content = '\n'.join(m)
return content
else:
return ''
if __name__ == '__main__':
local_ip = get_ip_address('eth0')
subject = '服务器[%s]日志报警了!' % local_ip
fromemail = 'xxxxxxxx@qq.com'
#emailpasswd为QQ邮箱的授权码
emailpasswd = 'mdkuasfhnjbrbhdj'
toemail = 'xxxxxx@qq.com'
alertlogfile = "/data/mysql/mysql_3306/log/error.log"
#pattern = ".*\[Warning\].*\s|.*\[Note\].*\s"
pattern = ".*Warning.*\s|.*error.*\s"
while True:
content = matchkeyword(pattern, alertlogfile)
if content:
sendemail(subject, content, fromemail, emailpasswd, toemail) python 监控日志并发送邮件报警
来源:这里教程网
时间:2026-02-28 08:37:48
作者:
编辑推荐:
- python 监控日志并发送邮件报警02-28
- 自动安装MySQL脚本02-28
- mysql在大型网站的应用架构演变02-28
- varchar和text说不清的那些事02-28
- PHP中mysql和mysqli的区别02-28
- mysql性能优化指南02-28
- 5个让DBA爱上你的SQL技巧02-28
- 15个初学者必看的基础SQL查询语句02-28
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- mysql在大型网站的应用架构演变
mysql在大型网站的应用架构演变
26-02-28 - 15个初学者必看的基础SQL查询语句
15个初学者必看的基础SQL查询语句
26-02-28 - 数据库的最简单实现
数据库的最简单实现
26-02-28 - 排名前十的SQL和NoSQL数据库
排名前十的SQL和NoSQL数据库
26-02-28 - sql json 简单介绍
sql json 简单介绍
26-02-28 - 优化mysql 还是使用缓存?
优化mysql 还是使用缓存?
26-02-28 - 数据库sql select查询的工作原理
数据库sql select查询的工作原理
26-02-28 - 四个经典的sql编程问题
四个经典的sql编程问题
26-02-28 - Mac下brew方式安装mysql
Mac下brew方式安装mysql
26-02-28 - Mysql 数据库操作基础及Node中使用Mysql
Mysql 数据库操作基础及Node中使用Mysql
26-02-28
