专栏名称: 马哥Linux运维
马哥linux致力于linux运维培训,连续多年排名第一,订阅者可免费获得学习机会和相关Linux独家实战资料!
目录
相关文章推荐
运维  ·  再见,CDN 巨头:Akamai 宣布 ... ·  2 天前  
51好读  ›  专栏  ›  马哥Linux运维

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

马哥Linux运维  · 公众号  · 运维  · 2018-10-22 22:00

正文

话不多说,直入正题。

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

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

一、监控所有的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状态的错误日志

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







请到「今天看啥」查看全文