日誌框架淺析

来源:https://www.cnblogs.com/Marvin-CD/archive/2019/03/15/10539585.html
-Advertisement-
Play Games

1. 日誌簡介 在Java項目中,日誌是必不可少的功能,日誌對於快速定位問題,檢查日常項目運行狀態等有非常重要的作用,但是目前Java日誌存在多種框架,如:Log4j、Log4j2、Commons Logging、Slf4j、Logback、Jul等。 2. 常用日誌框架 Log4j,Apache基 ...


                             

 

1. 日誌簡介

 

  在Java項目中,日誌是必不可少的功能,日誌對於快速定位問題,檢查日常項目運行狀態等有非常重要的作用,但是目前Java日誌存在多種框架,如:Log4j、Log4j2、Commons Logging、Slf4j、Logback、Jul等。

 

2. 常用日誌框架

 

  Log4j,Apache基金會項目,日誌實現框架。

  Log4j 2,是Log4j的升級產品,但是與Log4j不相容。

  Commons Logging,簡稱jcl,Apache基金會項目,日誌門面組件。

  Slf4j,日誌門面組件。

  Logback,日誌實現框架。 

  Jul, java官方的日誌實現框架。

  介紹到這裡大家可能比較疑惑,記錄日誌到底該用哪個組件,其實實現日誌記錄可以直接使用日誌實現框架,比如Logback、Log4j、Log4j2或者Jul,但是一旦這麼做如果碰到日誌組件更換或者升級,將會很麻煩,比如你需要去每一個使用日誌記錄的類中去修改,

 

  所以我們在項目中一般不直接使用日誌實現框架,而是使用外觀模式:日誌門面組件+橋接器+日誌實現框架,這樣即使項目更換日誌種類,只需更換橋接器和日誌實現框架,也就是只更換Jar包就可以了,代碼無需做任何改動。

  下圖表示了日誌門面組件、橋接器、日誌時間框架之間的關係:

 

 

3. 日誌選用

 

  建議選擇Slf4j+logback,相比其他組合相比有以下優勢:

    1) 限制較少,使用範圍更廣。

    2) 更好的性能,更低的開銷。

    3) 文檔免費

    4) Slf4j和Logback是同一個人開發,銜接好。

如果你不想使用該組合,也可以選用其他組合,很多人也使用Slf4j+Log4j,這裡把Slf4j和其他日誌實現框架組合和所需要的橋接器列出,可自行選用:

更詳細的Slf4j官網(https://www.slf4j.org/manual.html#swapping)示意圖如下:

 

 

 4. 問題處理

 

  實際上不單單存在日誌門面組件到日誌實現框架的橋接器,還存在另外一種橋接器,就是可以把日誌實現框架重定向到日誌門面組件,我們暫時就叫它“重定向橋接器”吧,例如:Log4j-over-slf4j-version.jar、jcl-over-slfj-version.jar(jcl雖然也是日誌門面組件,但是也可以實現重新定向),jul-over-slf4j-version.jar等。這些“重定向橋接器”的存在,不謹慎處理會造成一些異常,首先要知道,為什麼會存在這類橋接器?不要不行嗎?因為項目中你自己主動列印的日誌,可能是想用Slf4j+Logback,但是項目中使用了許多其他依賴,這些依賴用的日誌實現不盡相同,這時候就需要統一項目日誌記錄系統,所以就有了這些“重定向橋接器”。

  常見異常為:

 1)

  這種異常是因為Slf4j作為日誌門面介面,結果依賴中出現了多個不同日誌實現框架的橋接器,所以出現多重綁定的異常,如果你想使用logback作為日誌實現,那就保留logback-classic橋接器,屏蔽其他橋接器,想使用其他日誌實現框架的話同理。

2)

這種異常是因為Slf4j使用橋接器到某個日誌實現框架,然後該框架又使用“重定向橋接器”調用Slf4j,即“Slf4j -> 橋接器 -> 日誌實現框架 -> ‘重定向橋接器’-> Slf4j”,形成閉環,迴圈調用,從而堆棧溢出。解決辦法就是,屏蔽“重定向橋接器”,打破閉環。

舉例:

(1) slf4j-log4j12.jar和log4j-over-slf4j.jar共存,會形成Slf4j -> slf4j-log4j12 -> log4j -> log4j-over-slf4j -> Slf4j 的閉環,這個時候根據你實際項目使用日誌情況,打破閉環,比如你本身並不使用log4j作為日誌實現框架而用的是logback,那就可以屏蔽slf4j-log4j12.jar。

(2) Jul-to-slf4j.jar和slfj-jdk14.jar共存,方法同上。

 

 

5.查看衝突

 

  如果使用IDEA作為開發工具,可以很方便的看到依賴衝突的情況。

  (1) 打開項目的pom.xml文件,然後右擊->maven->Show Dependencies,如果沒有此項功能,請看一下File- > Plugins -> UMLSupport插件下了沒。

  (2) 然後出現如下,按住Ctrl,使用滑鼠滾輪可調整大小,Ctrl+F 可以搜索jar。

 

  (3) 連接帶紅線的就是有衝突的jar包,點擊該jar包會顯示版本信息,順著紅色虛線就可以找到衝突的jar包 , 然後對著衝突的jar包點擊右鍵,選擇Exclude就可以屏蔽衝突的jar包。

 

 


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

-Advertisement-
Play Games
更多相關文章
  • Python描述符的使用 前言 作為一位python的使用者,你可能使用python有一段時間了,但是對於python中的描述符卻未必使用過,接下來是對描述符使用的介紹 場景介紹 為了引入描述符的使用,我們先設計一個非常簡單的類: class Product(): def __init__(self ...
  • 加密視頻 在以後的開發項目中,很可能有做線上視頻的,而線上視頻就有個問題,因為線上播放,就很有可能視頻數據被抓包,如果這個線上視頻平臺有付費視頻的話,這樣就會有人做點倒賣視頻的生意了,針對這個問題,目前國內有很多不錯的加密視頻平臺,可以把你平臺的視頻放在他們那裡,然後通過他們的機制進行加密,然後做一... ...
  • 個人筆記,如有疏漏,還請指正。 使用多線程(threading)和多進程(multiprocessing)完成常規的併發需求,在啟動的時候 start、join 等步驟不能省,複雜的需要還要用 1 2 個隊列。 隨著需求越來越複雜,如果沒有良好的設計和抽象這部分的功能層次,代碼量越多調試的難度就越大 ...
  • 一、問題 BIO 和 NIO 作為 Server 端,當建立了 10 個連接時,分別產生多少個線程? 答案: 因為傳統的 IO 也就是 BIO 是同步線程堵塞的,所以每個連接都要分配一個專用線程來處理請求,這樣 10 個連接就會創建 10 個線程去處理。而 NIO 是一種同步非阻塞的 I/O 模型, ...
  • springboot 項目中讀取資源文件內容 如圖片、文檔文件 ...
  • 通過前面幾篇文章的學習,大家應能掌握幾種容器類型的常見用法,對於簡單的增刪改和遍歷操作,各容器實例都提供了相應的處理方法,對於實際開發中頻繁使用的清單List,還能利用Arrays工具的asList方法給清單對象做初始化賦值,另外提供了專門的Collections工具進行排序、求最大元素、求最小元素 ...
  • Java提供了一個this關鍵字,this關鍵字總是指向調用該方法的對象。根據this出現的位置的不同,this作為對象的預設引用有兩種情形。 1)構造器中引用該構造器正在初始化的對象。 2)在方法中引用調用該方法的對象。 this關鍵字最大的作用就是讓類中一個方法,訪問該類里的另一個方法或者實例變 ...
  • 下麵的代碼用於取4和2的中點,說明位移運算符優先順序低於加減: 而正確的寫法如下所示: 一般取中點的操作我們寫為 1 mid = low + ((high-low)>>1) 而不是 是考慮到了有可能會溢出的情況。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...