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

1、监控全部的request请求

如何实现系统监控,自动发送错误日志的邮件呢?html

只需配置配置settings文件便可。django

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

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

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处理系统日志发送邮件的handlercode

在没有配置filter参数状况下,默认发送系统5XX状态的错误日志orm

'handlers': {

    'mail_admin': {

    'level':'ERROR',

    'class':'django.utils.log.AdminEmailHandler',

    'include_html':False,

    }

}

2)配置django.request模块的logger 将django的request模块配置如上的mail_admin handlerhtm

'loggers': {

    'django.request': {

    'handlers': ['default','mail_admin'],

    'propagate':True,

    'level':'ERROR',

    },

}

  在这里仍是要推荐下我本身建的Python开发学习群:725479218,群里都是学Python开发的,若是你正在学习Python ,小编欢迎你加入,你们都是软件开发党,不按期分享干货(只有Python软件开发相关的),包括我本身整理的一份2018最新的Python进阶资料和高级开发教程,欢迎进阶中和进想深刻Python的小伙伴blog

2、监控非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)

效果以下

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

相关文章
相关标签/搜索