Flask學(xué)習(xí)筆記之日志操作配置實(shí)例講解
引言
之前在 Django 筆記里詳細(xì)介紹了 logging 模塊關(guān)于 formatters,handlers,loggers 等基礎(chǔ)介紹,這里就不做多的介紹了,詳情可以直接跳轉(zhuǎn)查看相應(yīng)文章:Django筆記三十之log日志的記錄詳解
這里直接介紹如何在 Flask 中配置日志信息。
本篇筆記的代碼都已經(jīng)提交到 github 上,可使用下面的操作獲取代碼:
git clone https://github.com/x1204604036/flask_backend.git
1、日志配置
首先,我們創(chuàng)建一些日志輸出的文件地址變量,在 config/config.py 中記錄,根據(jù)環(huán)境判斷來源于測試環(huán)境變量文件或者生產(chǎn)環(huán)境變量文件,我這里是在 development.py 中,內(nèi)容如下:
LOGGING_PATH = "e:/code/log_file/flask_backend/flask.log" LOGGING_ERROR_PATH = "e:/code/log_file/flask_backend/flask_error.log"
接著在 app/config/ 文件夾下創(chuàng)建一個(gè)文件 logging_config.py,內(nèi)容如下:
# app/config/logging_config.py
from app.config import config
LoggingConfig = {
"version": 1,
"formatters": {
"verbose": {
"format": "%(levelname)s %(asctime)s %(filename)s %(lineno)s %(message)s",
}
},
"handlers": {
"file": {
"level": "INFO",
"filename": config.LOGGING_PATH,
"formatter": "verbose",
"class": "logging.handlers.RotatingFileHandler",
'maxBytes': 5 * 1024 * 1024,
'backupCount': 20,
},
"error_handler": {
"level": "INFO",
"filename": config.LOGGING_ERROR_PATH,
"formatter": "verbose",
"class": "logging.handlers.RotatingFileHandler",
'maxBytes': 5 * 1024 * 1024,
'backupCount': 20,
},
"email_handler": {
"level": "WARNING",
"class": "logging.handlers.SMTPHandler",
"mailhost": ("smtp.163.com", 25),
"fromaddr": "hunterxxxxx@163.com",
"toaddrs": "120xxxx@qq.com",
"subject": "系統(tǒng)error",
"credentials": ("hunterxxxx@163.com", "JBDMVIxxxxx"),
"timeout": 20,
},
},
"root": {
"handlers": ["file"],
"level": "INFO",
"propagate": True,
},
"loggers": {
"error_log": {
"handlers": ["error_handler", "email_handler"],
"level": "INFO",
}
}
}這里創(chuàng)建了三個(gè) handler,兩個(gè) FileHandler 將日志以文件形式存儲,一個(gè)用于發(fā)送郵件
其下,root 表示用于記錄 Flask 全部信息的輸出,其他的 logger 都在 loggers 下記錄,在這里一個(gè)記錄 error 的 logger 對應(yīng)有兩個(gè) handler,一個(gè)記錄日志到文件,一個(gè)發(fā)送郵件。
在 app/__init__.py 中引入日志配置:
# app/__init__.py
import logging.config
from app.config import looging_config
def create_app():
app = Flask(__name__)
logging.config.dictConfig(looging_config.LoggingConfig)
return app2、日志打印示例
這里,我們以上一節(jié)中的異常處理為例進(jìn)行日志記錄,將日志輸出的代碼都放到異常處理中,exception_handler.py 內(nèi)容如下:
from werkzeug.exceptions import HTTPException
from flask import jsonify, request
import logging
import traceback
logger = logging.getLogger("error_log")
ERROR_HTTP_CODE = 417
class UserException(Exception):
def __init__(self, code=-1, msg="error", http_code=417):
self.code = code
self.msg = msg
self.http_code = http_code
def init_error_exception(app):
@app.errorhandler(HTTPException)
def handler_http_exception(exception):
trace_info = traceback.format_exc()
log_msg = "request path: %s, traceback info: %s, description: %s" % (
request.path, trace_info, exception.description
)
logger.info(log_msg)
return jsonify({"code": -1, "msg": exception.description}), exception.code
@app.errorhandler(Exception)
def server_exception(exception):
logger.info("request_path: " + request.path)
trace_info = traceback.format_exc()
log_msg = "request path: %s, traceback info: %s" % (request.path, trace_info)
logger.info(log_msg)
logger.error("系統(tǒng)報(bào)錯(cuò)信息:%s" % log_msg)
return jsonify({"code": -1, "msg": "內(nèi)部錯(cuò)誤"}), ERROR_HTTP_CODE
@app.errorhandler(UserException)
def user_exception(exception):
trace_info = traceback.format_exc()
log_msg = "request path: %s, traceback info: %s, exception msg: %s" % (
request.path, trace_info, exception.msg
)
logger.info(log_msg)
return jsonify({"code": exception.code, "msg": exception.msg}), exception.http_code這里,我們將請求路徑,報(bào)錯(cuò)信息等放到 log_msg 中,然后通過 logger.info() 輸出,另外,這里我們還嘗試對系統(tǒng)異常的處理發(fā)送郵件到指定郵箱。
注意:日志配置中的郵箱信息記得改成自己實(shí)際的,這里我對我的信息做了模糊處理。
重新運(yùn)行系統(tǒng)后,嘗試觸發(fā)這三種報(bào)錯(cuò),就可以在對應(yīng)的日志文件里看到錯(cuò)誤信息的輸出了,觸發(fā)了 error 的第二種 exception 異常處理還會發(fā)送郵件。
以上就是Flask學(xué)習(xí)筆記之日志操作實(shí)例講解的詳細(xì)內(nèi)容,更多關(guān)于Flask日志操作配置的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python 解決print數(shù)組/矩陣無法完整輸出的問題
這篇文章主要介紹了關(guān)于python 解決print數(shù)組/矩陣無法完整輸出的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
網(wǎng)絡(luò)瀏覽器中運(yùn)行Python腳本PyScript剖析
這篇文章主要為大家介紹了網(wǎng)絡(luò)瀏覽器中運(yùn)行Python腳本PyScript剖析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Jupyter Notebook切換虛擬環(huán)境的三種方法
本文主要介紹了Jupyter Notebook切換虛擬環(huán)境的三種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
基于Python實(shí)現(xiàn)自動(dòng)掃雷詳解
這篇文章主要介紹了如何利用Python+OpenCV實(shí)現(xiàn)了自動(dòng)掃雷,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Python有一定的幫助,需要的可以參考一下2022-01-01
Python使用到第三方庫PyMuPDF圖片與pdf相互轉(zhuǎn)換
今天為大家介紹個(gè)比較簡單的Python第三方庫PyMuPDF進(jìn)行圖片和pdf之間的相互轉(zhuǎn)換,以下就是利用PyMuPDF進(jìn)行pdf與圖片之間的互轉(zhuǎn)2019-05-05
基于循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)實(shí)現(xiàn)影評情感分類
這篇文章主要為大家詳細(xì)介紹了基于循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)實(shí)現(xiàn)影評情感分類,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
Python實(shí)現(xiàn)DBSCAN聚類算法并樣例測試
聚類是一種機(jī)器學(xué)習(xí)技術(shù),它涉及到數(shù)據(jù)點(diǎn)的分組,聚類是一種無監(jiān)督學(xué)習(xí)的方法,是許多領(lǐng)域中常用的統(tǒng)計(jì)數(shù)據(jù)分析技術(shù)。本文給大家分享Python實(shí)現(xiàn)DBSCAN聚類算法并樣例測試,感興趣的朋友一起看看吧2021-06-06
python excel轉(zhuǎn)換csv代碼實(shí)例
這篇文章主要介紹了python excel轉(zhuǎn)換csv代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08

