如何實現系統監控,自動發送錯誤日誌的郵件呢?html
只需配置配置settings文件便可。django
郵件會發送到ADMINS設定的郵件列表中。app
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'
1)配置mail_admin的handler學習
level爲日誌級別日誌
django.utils.log.AdminEmailHandler爲django處理系統日誌發送郵件的handlercode
在沒有配置filter參數狀況下,默認發送系統5XX狀態的錯誤日誌orm
'handlers': { 'mail_admin': { 'level':'ERROR', 'class':'django.utils.log.AdminEmailHandler', 'include_html':False, } }
2)配置django.request模塊的logger 將django的request模塊配置如上的mail_admin handlerhtm
'loggers': { 'django.request': { 'handlers': ['default','mail_admin'], 'propagate':True, 'level':'ERROR', }, }
在這裏仍是要推薦下我本身建的Python開發學習羣:725479218,羣裏都是學Python開發的,若是你正在學習Python ,小編歡迎你加入,你們都是軟件開發黨,不按期分享乾貨(只有Python軟件開發相關的),包括我本身整理的一份2018最新的Python進階資料和高級開發教程,歡迎進階中和進想深刻Python的小夥伴blog
如何監控例如系統的定時任務等非用戶發起的功能模塊,咱們能夠自定義一個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)
效果以下
以上監控方法,簡單實用,無需開發額外的日誌監控系統,能夠在第一時間發現系統的問題,並得知系統的錯誤日誌,幫助快速的定位問題。