5分鐘教你學會Django系統錯誤監控
話不多說,直入正題。
先上圖,看一下監控的效果。
如下是監控我們網站系統錯誤的郵件。包含了請求的url地址,以及詳細的異常信息。
一、監控所有的request請求
如何實現系統監控,自動發送錯誤日誌的郵件呢?
只需配置配置settings文件即可。
1.設置發送郵件配置信息
郵件會發送到ADMINS設定的郵件列表中。
SERVER_EMAIL =sender@qq.com
DEFAULT_FROM_EMAIL =sender@qq.comADMINS = ((receiver,receiver@qq.com),)EMAIL_HOST =smtp.exmail.qq.comEMAIL_HOST_USER =sender@qq.comEMAIL_HOST_PASSWORD =123456EMAIL_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知識體系,你可以看一下我們花費了一個多月整理了上百小時的幾百個知識點體系內容:
【超全整理】《Python自動化全能開發從入門到精通》筆記全放送
本文轉自:馬哥linux運維(微信號:magedu-Linux)
為了方便大家學習,我建立了一個馬哥Python交流群,目前群內已經有2000多個小夥伴,學習寂寞的小夥伴不妨一起來玩~群號:515237230
推薦閱讀:
※Python從零開始系列連載(24)——Python特色數據類型(集合)(上)
※Python從零開始系列連載(11)——Python的基本運算和表達式(中二)
※PyQt5番外篇(1):PyQt5與Opencv的小小融合
※Python:圖片轉字元畫
※快收藏了!GitHub 上最火最值得看的 Python 開源項目