如何实现系统监控,自动发送错误日志的邮件呢?
只需配置配置settings文件即可。
邮件会发送到ADMINS设定的邮件列表中。
SERVER_EMAIL ='sender@qq.com'
DEFAULT_FROM_EMAIL ='sender@qq.com'
ADMINS = (('receiver','receiver@qq.com'),)
EMAIL_HOST ='smtp.exmail.qq.com'
EMAIL_HOST_USER ='sender@qq.com'
EMAIL_HOST_PASSWORD ='123456'
EMAIL_BACKEND ='django.core.mail.backends.smtp.EmailBackend'
1)配置mail_admin的handler
level为日志级别
django.utils.log.AdminEmailHandler为django处理系统日志发送邮件的handler
在没有配置filter参数情况下,默认发送系统5XX状态的错误日志
'handlers': {
'mail_admin': {
'level':'ERROR',
'class':'django.utils.log.AdminEmailHandler',
'include_html':False,
}
}
2)配置django.request模块的logger
将django的request模块配置如上的mail_admin handler
'loggers': {
'django.request': {
'handlers': ['default','mail_admin'],
'propagate':True,
'level':'ERROR',
},
}
在这里还是要推荐下我自己建的Python开发学习群:725479218,群里都是学Python开发的,如果你正在学习Python ,小编欢迎你加入,大家都是软件开发党,不定期分享干货(只有Python软件开发相关的),包括我自己整理的一份2018最新的Python进阶资料和高级开发教程,欢迎进阶中和进想深入Python的小伙伴
如何监控例如系统的定时任务等非用户发起的功能模块,我们可以自定义一个decorator来解决这个问题。
utils.send_exception_email(email_list,title,exc)为发送邮件的方法,可以自己实现,非常简单
def decorator_error_monitor(title):
def wrap(f):
def wrapped_f(*args,**kwargs):
try:
result = f(*args,**kwargs)
return result
except:
exc = traceback.format_exc()
utils.send_exception_email(email_list,title,exc)
raise Exception(exc)
return wrapped_f
return wrap
对需要监控的方法使用decorator
@decorator_error_monitor("清算错误")
def do_settlement(users):
for user in users:
process_settlement_for_one_user(user)
效果如下
以上监控方法,简单实用,无需开发额外的日志监控系统,可以在第一时间发现系统的问题,并得知系统的错误日志,帮助快速的定位问题。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款