您现在的位置是:首页 > 文章详情

Python | 5分钟教你学会Django系统错误监控

日期:2018-11-01点击:358

话不多说,直入正题。

先上图,看一下监控的效果。

如下是监控我们网站系统错误的邮件。包含了请求的url地址,以及详细的异常信息。

633827b8ba65443f46b5e16ce4ea0f057c708eb0

一、监控所有的request请求

如何实现系统监控,自动发送错误日志的邮件呢?只需配置配置settings文件即可。

1.设置发送邮件配置信息

邮件会发送到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'

2.配置LOGGING

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', }, }

二、监控非request请求

如何监控例如系统的定时任务等非用户发起的功能模块,我们可以自定义一个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)
监控效果如下图所示:

921324a4b3d0462fc608e82c952a46c3a62c60a7

小结

以上监控方法,简单实用,无需开发额外的日志监控系统,可以在第一时间发现系统的问题,并得知系统的错误日志,帮助快速的定位问题。

原文发布时间为:2018-10-31

本文作者:上海小胖

本文来自云栖社区合作伙伴“Python专栏”,了解相关信息可以关注“Python专栏”。

原文链接:https://yq.aliyun.com/articles/663227
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章