flask日誌

来源:https://www.cnblogs.com/liao-lei/archive/2018/11/05/9906776.html
-Advertisement-
Play Games

日誌功能的實現 Python 自身提供了一個用於記錄日誌的標準庫模塊:logging。 logging 模塊 logging 模塊定義的函數和類為應用程式和庫的開發實現了一個靈活的事件日誌系統 logging 模塊是 Python 的一個標準庫模塊,由標準庫模塊提供日誌記錄 API 的關鍵好處是所有 ...


日誌功能的實現

Python 自身提供了一個用於記錄日誌的標準庫模塊:logging。

logging 模塊

  • logging 模塊定義的函數和類為應用程式和庫的開發實現了一個靈活的事件日誌系統
  • logging 模塊是 Python 的一個標準庫模塊,由標準庫模塊提供日誌記錄 API 的關鍵好處是所有 Python 模塊都可以使用這個日誌記錄功能。

logging 模塊的日誌級別

  • logging模塊預設定義了以下幾個日誌等級,它允許開發人員自定義其他日誌級別,但是這是不被推薦的,尤其是在開發供別人使用的庫時,因為這會導致日誌級別的混亂。
    • DEBUG 最詳細的日誌信息,典型應用場景是 問題診斷
    • INFO 信息詳細程度僅次於DEBUG,通常只記錄關鍵節點信息,用於確認一切都是按照我們預期的那樣進行工作
    • WARNING 當某些不期望的事情發生時記錄的信息(如,磁碟可用空間較低),但是此時應用程式還是正常運行的
    • ERROR 由於一個更嚴重的問題導致某些功能不能正常運行時記錄的信息
    • FATAL/CRITICAL 整個系統即將/完全崩潰
  • 開發應用程式或部署開發環境時,可以使用 DEBUG 或 INFO 級別的日誌獲取儘可能詳細的日誌信息來進行開發或部署調試;
  • 應用上線或部署生產環境時,應該使用 WARNING 或 ERROR 或 CRITICAL 級別的日誌來降低機器的I/O壓力和提高獲取錯誤日誌信息的效率。

日誌級別的指定通常都是在應用程式的配置文件中進行指定的。

logging 模塊的使用方式介紹

  • loggers 提供應用程式代碼直接使用的介面
  • handlers 用於將日誌記錄發送到指定的目的位置
  • filters 提供更細粒度的日誌過濾功能,用於決定哪些日誌記錄將會被輸出(其它的日誌記錄將會被忽略)
  • formatters 用於控制日誌信息的最終輸出格式
# 設置日誌的記錄等級
logging.basicConfig(level=logging.DEBUG) # 調試debug級
# 創建日誌記錄器,指明日誌保存的路徑、每個日誌文件的最大大小、保存的日誌文件個數上限
file_log_handler = RotatingFileHandler("logs/log", maxBytes=1024*1024*100, backupCount=10)
# 創建日誌記錄的格式 日誌等級 輸入日誌信息的文件名 行數 日誌信息
formatter = logging.Formatter('%(levelname)s %(filename)s:%(lineno)d %(message)s')
# 為剛創建的日誌記錄器設置日誌記錄格式
file_log_handler.setFormatter(formatter)
# 為全局的日誌工具對象(flask app使用的)添加日誌記錄器
logging.getLogger().addHandler(file_log_handler)

使用logging提供的模塊級別的函數記錄日誌

最簡單的日誌輸出

  • 先來試著分別輸出一條不同日誌級別的日誌記錄:
import logging

logging.debug("This is a debug log.")
logging.info("This is a info log.")
logging.warning("This is a warning log.")
logging.error("This is a error log.")
logging.critical("This is a critical log.")
  • 也可以這樣寫:
logging.log(logging.DEBUG, "This is a debug log.")
logging.log(logging.INFO, "This is a info log.")
logging.log(logging.WARNING, "This is a warning log.")
logging.log(logging.ERROR, "This is a error log.")
logging.log(logging.CRITICAL, "This is a critical log.")

修改配置改變輸出內容

logging.basicConfig(level=logging.DEBUG)

切記:設置 Configurations 中的 Working directory 為當前項目

集成日誌到當前項目

  • 在 config.py 文件中在不同的環境的配置下添加日誌級別
class Config(object):
    ...

    # 預設日誌等級
    LOG_LEVEL = logging.DEBUG


class ProductionConfig(Config):
    """生產模式下的配置"""
    LOG_LEVEL = logging.ERROR
  • 在 info 目錄下的 init.py 文件中添加日誌配置的相關方法
def setup_log(config_name):
    """配置日誌"""

    # 設置日誌的記錄等級
    logging.basicConfig(level=config[config_name].LOG_LEVEL)  # 調試debug級
    # 創建日誌記錄器,指明日誌保存的路徑、每個日誌文件的最大大小、保存的日誌文件個數上限
    file_log_handler = RotatingFileHandler("logs/log", maxBytes=1024 * 1024 * 100, backupCount=10)
    # 創建日誌記錄的格式 日誌等級 輸入日誌信息的文件名 行數 日誌信息
    formatter = logging.Formatter('%(levelname)s %(filename)s:%(lineno)d %(message)s')
    # 為剛創建的日誌記錄器設置日誌記錄格式
    file_log_handler.setFormatter(formatter)
    # 為全局的日誌工具對象(flask app使用的)添加日誌記錄器
    logging.getLogger().addHandler(file_log_handler)
  • 在 create_app 方法中調用上一步創建的方法,並傳入 config_name
def create_app(config_name):
    ...

    # 配置項目日誌
    setup_log(config_name)
    app = Flask(__name__)
    ...
  • 在項目根目錄下創建日誌目錄文件夾 logs,如下:
  • 運行項目,當前項目日誌已輸出到 logs 的目錄下自動創建的 log 文件中

    • 在 logs 文件夾下創建 .gitkeep 文件,以便能將 logs 文件夾添加到遠程倉庫,併在 .gitignore 文件中添加忽略提交生成的日誌文件
    logs/log*
    

    在 Flask框架 中,其自己對 Python 的 logging 進行了封裝,在 Flask 應用程式中,可以以如下方式進行輸出 log:

    current_app.logger.debug('debug')
    current_app.logger.error('error')
  • 當前應用程式的 logger 會根據應用程式的調試狀態去調整日誌級別,如下圖:

     

     


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • AngularJS是一款來自Google的前端JS框架,它的核心特性有:MVC、雙向數據綁定、指令和語義化標簽、模塊化工具、依賴註入、HTML模板,以及對常用工具的封裝,例如$http、$cookies、$location等。AngularJS框架的體積非常小,但是設計理念和功能卻非常強大,值得前端 ...
  • JavaScript: 知識點回顧篇(八):js中的瀏覽器對象 ...
  • 本教程基於angular7(2018 11 04) 1. 安裝node.js 下載地址: http://nodejs.cn/download/ 下載對應自己操作系統的版本安裝即可。 2.安裝 angular cli開發套件 安裝命令: 3.創建一個新的項目 ​ 會自動打開瀏覽器並預覽項目,如不能自動 ...
  • 設計模式的本質是為了遵循設計原則,設計模式是設計原則的具體化表現形式,本文對六大設計原則進行了簡單介紹,開閉原則是根本,單一職責,里氏替換,介面隔離,依賴倒置,組合聚合法則以及迪米特法則,對設計模式進行了一個淺淺的介紹,以進一步往後學習設計模式。 ...
  • 機票實時搜索系統架構設計• 不同的業務場景,不同的特征 • 結合特征去進⾏設計和優化 • 通⽤!=最優 • 量體裁⾐分散式系統的CAP理論 首先把分散式系統中的三個特性進行瞭如下歸納: ● 一致性(C):在分散式系統中的所有數據備份,在同一時刻是否同樣的值。(等同於所有節點訪問同一份最新的數據副本)... ...
  • 前言 開心一刻 小白問小明:“你前面有一個5米深的坑,裡面沒有水,如果你跳進去後該怎樣出來了?”小明:“躺著出來唄,還能怎麼出來?”小白:“為什麼躺著出來?”小明:“5米深的坑,還沒有水,跳下去不死就很幸運了,殘是肯定會殘的,不躺著出來,那能怎麼出來?”小白:“假設沒死也沒殘呢?”小明:“你當我超人 ...
  • 首先是恭喜IG獲得S8全球總決賽冠軍,IG牛逼。但咱是一介草民,狂歡後,還是得老老實實的開始敲代碼。 最近做了一個給底層固件壓縮加密的工具,是使用C 做的,已經提交出去可以正常使用的。既然在學習Go語言, 那我很慣性的想到,能不能使用Go來做這塊,咱界面還是使用winform,壓縮這一塊可以使用Go ...
  • 基本類型直接存儲在堆棧中 基本類型所具有的包裝容器,使得可以在堆中創建一個非基本對象,用來表示對應的基本類型 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...