5分钟教你学会Django系统错误监控!不信?事实证明只需五分钟!

5分钟教你学会Django系统错误监控!不信?事实证明只需五分钟!,第1张

概述   一、监控所有的request请求如何实现系统监控,自动发送错误日志的邮件呢?只需配置配置settings文件即可。

一、监控所有的request请求

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

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

邮件会发送到adminS设定的邮件列表中。

SERVER_EMAIL ='[email protected]'DEFAulT_FROM_EMAIL ='[email protected]'adminS = (('receiver','[email protected]'),)EMAIL_HOST ='smtp.exmail.qq.com'EMAIL_HOST_USER ='[email protected]'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状态的错误日志

进群:548377875  即可获取大量的学习资料哦以及数十套从零到项目的pdf哦!

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

监控效果如下图所示:

小结

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

总结

以上是内存溢出为你收集整理的5分钟教你学会Django系统错误监控!不信?事实证明只需五分钟!全部内容,希望文章能够帮你解决5分钟教你学会Django系统错误监控!不信?事实证明只需五分钟!所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1208586.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存