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

枫铃3年前 (2021-06-26)Python261

话不多说,直入正题。

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

如下是监控我们网站系统错误的邮件。包含了请求的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

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,互帮互助,
群里还有不错的视频学习教程和PDF电子书!
'''
'loggers': {
    'django.request': {
    'handlers': ['default','mail_admin'],
    'propagate':True,
    'level':'ERROR',
    },
}

二、监控非request请求

如何监控例如系统的定时任务等非用户发起的功能模块,我们可以自定义一个decorator来解决这个问题。

utils.send_exception_email(email_list,title,exc)为发送邮件的方法,可以自己实现,非常简单

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,互帮互助,
群里还有不错的视频学习教程和PDF电子书!
'''
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类的命名空间与组合

一、类的命名空间 定义:我们在创建一个类的时候就会创建一个类的命名空间,用来存储类中定义的所有的名字,这些名字称为...

Python容器类型公共方法汇总

以下公共方法支持列表&#...

python中8大排序(原理+代码)

常用的排序方法:冒泡排序、选择排序、插入排序、快速排序、堆排序、归并排序 冒泡排序(Bubble Sort): 比较相邻的元素...

Python 中的 sys.argv 用法

sys.argv是获取运...

零基础学Python:函数的参数详解

必备参数关键字参数默认参...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。