」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 log4j 根據日誌記錄等級和目標類別建立具有不同內容的多個日誌檔案?

如何使用 log4j 根據日誌記錄等級和目標類別建立具有不同內容的多個日誌檔案?

發佈於2024-11-08
瀏覽:983

How can log4j be used to create multiple log files with varying content based on logging levels and target classes?

使用log4j 進行日誌記錄的彈性:使用可變內容配置多個日誌檔案

在使用log4j 進行日誌記錄的領域中,需要多功能且有針對性的經常會遇到日誌記錄機制。其中一個場景涉及建立多個日誌文件,每個日誌文件包含特定目標類別的不同等級的日誌記錄資訊。

Log4j 的可配置日誌記錄層級

為了實現這一點,log4j提供配置多個附加程式的能力,每個附加程式都定義有特定的閾值級別。閾值等級規定了附加程序將處理的最低日誌記錄等級。透過設定不同的閾值級別,您可以根據日誌訊息的嚴重性將日誌訊息路由到不同的附加程式。

建立多個日誌檔案

例如,捕獲所有INFO 及以上一個日誌檔案中的訊息以及單獨檔案中類別子集的所有DEBUG 訊息,您可以配置以下log4j settings:

log4j.rootLogger=QuietAppender, LoudAppender, TRACE

此行定義根記錄器,它適用於所有類別,除非被特定記錄器配置覆蓋。它分配三個附加程式:「QuietAppender」用於INFO 及以上訊息,「LoudAppender」用於DEBUG 及以上訊息,「TRACE」用於所有訊息(討論了一個特殊的附加程式)下面).

log4j.appender.QuietAppender=org.apache.log4j.RollingFileAppender

log4j.ap pender.QuietAppender.Threshold=INFO

&&&]log4j.appender.QuietAppender.File=quiet.log

The QuietAppender 設定為將INFO 和上述訊息附加到「quiet.log」檔案.

log4j .appender.LoudAppender=org.apache.log4j.RollingFileAppender

log4j.app ender.LoudAppender.Threshold=DEBUG

log4j. LoudAppender.File=loud.log

LoudAppender 設定為將DEBUG 及以上訊息附加到「loud.log」檔案中。

log4j.logger.com.yourpackage.yourclazz=TRACE

此行新增「com.yourpackage」套件中特定類別的自訂記錄器。它會覆蓋根記錄器配置並將閾值設為 TRACE,確保記錄此類的所有訊息,無論根記錄器或附加器中設定的閾值等級為何。

透過組合這些配置,您可以實現客製化的日誌記錄功能,根據嚴重性和目標類別分隔日誌訊息,建立具有不同內容的多個日誌檔案以滿足特定用例。

最新教學 更多>
  • 像程式設計師一樣思考:學習 C 基礎知識
    像程式設計師一樣思考:學習 C 基礎知識
    以程式設計師思考學習 C 語言:基本語法:變數、資料型態、常數、運算子、控制流。實戰案例:計算兩個數的平均值,輸入兩個整數並計算其平均值。 以程式設計師思考:用C 語言學習基礎引言學習程式設計並不難,尤其是當你以程式設計師思維思考時。本文將從基礎開始,用 C 語言引導你逐步了解程式設計入門知識。 C...
    程式設計 發佈於2024-11-08
  • Python 中的列表理解語法何時需要三元運算子?
    Python 中的列表理解語法何時需要三元運算子?
    列表理解難題:可迭代物件中的條件篩選在Python 中,列表理解提供了一種基於現有可迭代物件建立清單的簡潔方法。然而,出現了一個關於涉及 if 語句的列表理解的問題。 目標是比較兩個可迭代物件 a 和 b,並僅列印兩者中出現的元素。預期的程式碼如下所示:print([y if y not in b ...
    程式設計 發佈於2024-11-08
  • 使用 MetaTrader 訂單管理和市場資料收集進行自動交易
    使用 MetaTrader 訂單管理和市場資料收集進行自動交易
    Your AsimovMT class provides a comprehensive interface for interacting with MetaTrader5 (MT5) using Python. However, there are several areas in your c...
    程式設計 發佈於2024-11-08
  • Python 清單的最大大小是多少以及它如何影響功能?
    Python 清單的最大大小是多少以及它如何影響功能?
    Python列表的最大大小:綜合分析在Python中,列表是基本的資料結構,可以容納多個不同類型的元素。它們的多功能性和靈活性使得了解它們的局限性至關重要,特別是在處理大型數據集時。本文探討了 Python 清單可以達到的最大大小及其對其功能的影響。 最大清單大小Python 清單的最大大小已定義通...
    程式設計 發佈於2024-11-08
  • 託管平台清單:綜合指南
    託管平台清單:綜合指南
    在數位時代,可靠的託管平台對於任何線上展示都至關重要,無論是個人部落格、電子商務網站還是公司網站。有無數的選項可供選擇,選擇合適的託管平台可能會令人畏懼。本指南將幫助您瀏覽當今一些最好的託管平台,比較它們的功能、價格和對不同需求的適用性。 1. 藍色主機 概述:Bluehost 是...
    程式設計 發佈於2024-11-08
  • 在瀏覽器中將影片壓縮為 webm
    在瀏覽器中將影片壓縮為 webm
    ?增強您的網路影片:使用 React 將 MP4 壓縮為 WebM 工作中沒有任何有趣的事情感到無聊嗎?好吧,就在那時我決定抓緊時間修補瀏覽器 API 的當前狀態。我們可以直接透過 Web API 壓縮影片嗎?在這篇部落格中,我將向您展示如何使用現代瀏覽器功能將 MP4 影片壓縮為...
    程式設計 發佈於2024-11-08
  • 現代 PHP 中的 PHP Fiber 並發性
    現代 PHP 中的 PHP Fiber 並發性
    PHP Fibers 在 PHP 8.1 中引入,帶來了一種令人興奮的新方法來處理 PHP 中的並發和非同步程式設計。纖維可讓您在執行過程中暫停和恢復函數,使開發人員能夠更好地控制非阻塞操作,例如處理 I/O、資料庫查詢或 HTTP 請求,而無需停止整個腳本。 在本部落格中,我們將探討 PHP 纖...
    程式設計 發佈於2024-11-08
  • Laravel 的新時代:Accel 的百萬美元 A 輪融資——這就是為什麼它改變了遊戲規則!
    Laravel 的新時代:Accel 的百萬美元 A 輪融資——這就是為什麼它改變了遊戲規則!
    各位,请戴好帽子! Laravel 刚刚发布了一些激动人心的消息,震惊了开发界——由 Accel 领投的 A 轮融资 5700 万美元。作为一名热情的 Laravel 用户和企业家同事,这一公告在整个 PHP 社区引起了震动,我感到非常兴奋!那么,让我们来分析一下为什么这项投资意义重大,以及为什么 ...
    程式設計 發佈於2024-11-08
  • C++11 的 `string::c_str()` 仍然以 Null 終止嗎?
    C++11 的 `string::c_str()` 仍然以 Null 終止嗎?
    C 11 的 string::c_str() 是否消除空終止? 在 C 11 中,string::c_str 不再保證產生一個以 null 結尾的字串。 原因:在C 11 中,string::c_str 的定義與string::data 相同,而string::data 又被定義相當於*( begi...
    程式設計 發佈於2024-11-08
  • 資料分析師清單
    資料分析師清單
    SQL 清單 Excel女士清單 Power BI 清單 Tableau 清單 Python 清單 請關注此 WhatsApp 頻道以獲取更多資源
    程式設計 發佈於2024-11-08
  • 如何在 Go 中將 YAML 欄位動態解析為有限結構集?
    如何在 Go 中將 YAML 欄位動態解析為有限結構集?
    在 Go 中將 YAML 欄位動態解析為有限結構體集簡介在 Go 中將 YAML 解析為結構體非常簡單。但是,當 YAML 欄位可以表示多個可能的結構時,任務就會變得更加複雜。本文探討了使用 Go 的 YAML 套件的動態方法。 使用 YAML v2 進行動態解組對於 Yaml v2,可以使用以下方...
    程式設計 發佈於2024-11-08
  • 為什麼我的 C++ 程式碼中會出現「vtable」和「typeinfo」未定義符號錯誤?
    為什麼我的 C++ 程式碼中會出現「vtable」和「typeinfo」未定義符號錯誤?
    未定義的符號:「vtable」和「typeinfo」在提供的程式碼中,出現連結錯誤並顯示下列訊息: Undefined symbols: "vtable for Obstacle", referenced from: Obstacle::Obstacle()in ...
    程式設計 發佈於2024-11-08
  • 如何在 Python 中執行指數和對數曲線擬合?
    如何在 Python 中執行指數和對數曲線擬合?
    曲線擬合:Python 中的指數和對數方法雖然Python 中可以使用polyfit() 輕鬆進行多項式曲線擬合,但本指南探討了指數和對數曲線的方法擬合。 對數擬合擬合 y 形式的直線= A B log x,只需執行 y 對 log x 的多項式擬合。 import numpy as np x = ...
    程式設計 發佈於2024-11-08
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-08
  • 如何實現ES6模組的條件導入?
    如何實現ES6模組的條件導入?
    ES6模組的條件導入在ES6中,'import'和'export'關鍵字只能出現在模組的頂層模組。這可以防止條件導入,這是許多應用程式中的常見要求。這個問題探討了這個問題的解決方案。 最初,使用者嘗試使用條件語句匯入模組,但這導致了語法錯誤。然後,使用者使用 Syst...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3