话不多说,直入正题。

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

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

监控效果如下图所示:

小结

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

django异常日志_5分钟教你学会Django系统错误监控相关推荐

  1. 一分钟教你学会python_十分钟教你学会python编写小游戏

    原标题:十分钟教你学会python编写小游戏 看过,估计大家都已经精通了吧,好的,话不多说,今天就活学活用,用python来编写纸牌游戏21点,江湖人称黑杰克,BLACK JACK-(注意法式卷舌). ...

  2. java连接数据库 oracle,Oracle数据库之一分钟教你学会用java连接Oracle数据库

    本文主要向大家介绍了Oracle数据库之一分钟教你学会用java连接Oracle数据库,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助. package java_jdbc; // ...

  3. 元件怎么反转_电气图纸怎么看?三分钟教你学会看懂,受用一生

    图纸一般用于设计方面,设计师绘制出图纸,我们再根据图纸进行操作,尤其是电气图纸,上面有很多符号,很难看懂,下面通过三分钟教你学会看懂电气图纸. 一.什么是电气图 用电气图形符号.带注释的围框或简化外形 ...

  4. 入门必看 | 三分钟教你学会操作台式万用表

    入门必看 | 三分钟教你学会操作台式万用表 入门必看 | 三分钟教你学会操作台式万用表

  5. 10分钟学计算机,电脑运行越来越慢?程序员大牛10分钟教你学会电脑瘦身

    原标题:电脑运行越来越慢?程序员大牛10分钟教你学会电脑瘦身 你的电脑是不是越来越慢?这里让程序员大佬用10分钟时间教你学会给电脑软件瘦身,1分钟了解计算机硬件升级.分分钟让你成为别人眼中的计算机大牛 ...

  6. 3分钟教你学会速卖通开店!干货来了!!!

    3分钟教你学会速卖通开店!干货来了!!! 近期有很多小伙伴都在问我,速卖通开店怎么开?具体流程是怎样的?有些怎样的费用?今天我就给大家讲讲速卖通开店的具体流程,以及所涉及到的一些费用,学会后3分钟就能 ...

  7. python编写小游戏17_十分钟教你学会python编写小游戏

    原标题:十分钟教你学会python编写小游戏 看过,估计大家都已经精通了吧,好的,话不多说,今天就活学活用,用python来编写纸牌游戏21点,江湖人称黑杰克,BLACK JACK-(注意法式卷舌). ...

  8. 【Linux + Makefile】十分钟教你学会Makefile的FORCE

    相信大家在使用Linux环境编程的时候,一定接触过Makefile这个玩意.Makefile在搭建自定义的编译环境,尤其是自动化编译.多功能一键编译等功能上,还是发挥了很大的作用.如果接触过Linux ...

  9. vue前端用服务器上路径的图片展示_5分钟教你用nodeJS手写一个mock数据服务器

    对于前端开发者而言,javascript正扮演着越来越重要的地位,它不仅能为浏览器端赋能,在web服务器方面也有很大的价值(我们可以用nodeJS来写服务端代码,启动web服务器),因此本文所要描述的 ...

最新文章

  1. plc原理及应用_施耐德PLC应用技术
  2. 三星s8怎么分屏操作_三星手机该怎么玩?了解完这几点用机技巧,可以轻车熟路了!...
  3. Asp.Net Core Filter 深入浅出的那些事-AOP
  4. Powershell 批量替换文件
  5. ComboGrid 行内点击编辑内容
  6. linux 版本信息 64位,Centos查看版本信息
  7. 软件测试中期答辩,毕业中期答辩模板ppt课件
  8. 云服务器部署 Web 项目
  9. BF,KMP算法(万字图文详解)
  10. vue2 html引入jquery,Vue添加引入jquery插件
  11. 以洪荒之力打开linux德·摩根定律
  12. 去掉mysql u0000_js对于\u0000的处理
  13. 深度学习CTR模型粗略记录
  14. 视频分享 500 G JAVA视频网盘分享(JEECG开源社区)
  15. 解决gpu没有运行进程,但是显存一直占用的方式
  16. 卷积神经网络实现人脸表情识别
  17. ObjectARX类库简介
  18. EtherCAT学习笔记:周期性过程数据通信
  19. SkyWalking 详细安装
  20. python嵌入式怎么学_怎么自学嵌入式?

热门文章

  1. spark之4:基础指南(源自官方文档)
  2. 【Lucene4.8教程之一】使用Lucene4.8进行索引及搜索的基本操作
  3. java常见的时间处理工具类
  4. Spark Streaming 实战案例(二) Transformation操作
  5. Docker入门总结
  6. LDA 线性判别分析模型
  7. Django 电脑使用管理
  8. 屏幕适配 部分知识点总结,CSDN小冰原创
  9. GitHub发布桌面版但不包括Linux
  10. 网页中启动QQ的 XX 命令