Python黑科技,教你学会Django系统错误监控
生活随笔
收集整理的這篇文章主要介紹了
Python黑科技,教你学会Django系统错误监控
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
話不多說,直入正題。
先上圖,看一下監控的效果。
如下是監控我們網站系統錯誤的郵件。包含了請求的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 resultexcept:exc = traceback.format_exc()utils.send_exception_email(email_list, title, exc)raise Exception(exc)return wrapped_freturn wrap對需要監控的方法使用decorator
@decorator_error_monitor("清算錯誤") def do_settlement(users):for user in users:process_settlement_for_one_user(user)監控效果如下圖所示:
小結
以上監控方法,簡單實用,無需開發額外的日志監控系統,可以在第一時間發現系統的問題,并得知系統的錯誤日志,幫助快速的定位問題。
總結
以上是生活随笔為你收集整理的Python黑科技,教你学会Django系统错误监控的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用python进行面部合成,比PS好用
- 下一篇: Linux优化不知如何下手?那你的看看这