python系统错误_Python黑科技,教你学会Django系统错误监控

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

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

一、监控所有的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)为发送邮件的方法,可以自己实现,非常简单

defdecorator_error_monitor(title):defwrap(f):defwrapped_f(*args,**kwargs):try:result=f(*args,**kwargs)returnresult except:exc=traceback.format_exc()utils.send_exception_email(email_list,title,exc)raiseException(exc)returnwrapped_freturnwrap

对需要监控的方法使用decorator

@decorator_error_monitor("清算错误")defdo_settlement(users):foruserinusers:process_settlement_for_one_user(user)

监控效果如下图所示:

小结

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值