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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...