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

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

来源:http://www.jianshu.com/p/42e4287ffeda

话不多说,直入正题。

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

如下是监控我们网站系统错误的邮件。包含了请求的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)为发送邮件的方法,可以自己实现,非常简单

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)

监控效果如下图所示:

小结

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

本文分享自微信公众号 - Python专栏(xpchuiit)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-10-31

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【底层原理】数据库的最简单实现

    链接:http://www.ruanyifeng.com/blog/2014/07/

    用户1634449
  • 内推 | 第十一期:运维开发工程师

    2. 梳理优化系统后台数据库的性能,保证执行效率,建立相关备份与恢复机制,保障数据存储安全;

    用户1634449
  • 如果鲁迅先生来写Python的话……

    用户1634449
  • 5分钟教你学会Django系统错误监控

    话不多说,直入正题。 先上图,看一下监控的效果。 如下是监控我们网站系统错误的邮件。包含了请求的url地址,以及详细的异常信息。 一、监控所有的request...

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

    django.utils.log.AdminEmailHandler为django处理系统日志发送邮件的handler

    小小科
  • 第七章:SpringBoot整合JavaMail发送邮件

    恒宇少年
  • 走进Java接口测试之使用JavaMailSender发送邮件

    一般我们在做接口自动化时,都会通过钉钉或者邮件的方式通知测试结果信息。而且基本上邮件的内容都是测试报告。所以,今天就来讲讲如何利用 pring提供的 JavaM...

    小老鼠
  • 程序员常用软件,你用了哪些

    编程软文
  • 关于钓鱼邮件的学习笔记

    所以事前我们需要准备一个钓鱼网站,为了能让钓鱼网站在公网访问,还需要一个VPS,若想获得更好的伪装效果,还需要一个用于伪装的域名。VPS和域名都到手后,还可以搭...

    FB客服
  • 如何避免成为垃圾邮件

    邮件营销经常会碰到的一个问题就是:发出去的邮件被系统当做垃圾邮件,直接进了垃圾箱,下面一米软件就来教教大家如何避免成为垃圾邮件。

    用户3736847

扫码关注云+社区

领取腾讯云代金券