Spring 核心技術解析【純干貨版】- XIX:Spring 日志模塊 Spring-Jcl 模塊精講

在現代 Java 開發中,日志是調試、監控和維護應用程序的重要工具。Spring 作為企業級框架,提供了 Spring-Jcl 作為日志抽象層,使開發者可以靈活切換不同的日志實現,而無需修改業務代碼。本篇文章將深入解析 Spring-Jcl 模塊,并通過一個 案例,展示如何集成 Log4j 進行日志管理,助力高效開發和問題排查。


文章目錄

      • 1、Spring-Jcl 模塊介紹
        • 1.1、Spring-Jcl 模塊概述
        • 1.2、Spring-Jcl 模塊依賴
        • 1.3、Spring-Jcl 模塊作用
      • 2、Spring WebSocket 案例
        • 2.1、項目依賴
        • 2.2、配置 Log4j
        • 2.3、編寫日志示例
        • 2.4、運行結果
      • X、后記


1、Spring-Jcl 模塊介紹

1.1、Spring-Jcl 模塊概述

Spring JCL模塊,是 Spring 中用以提供日志支持的模塊,其中 JCL 指的是 Java Commons Logging。

Spring JCL模塊提供了 Spring 框架對 Apache Commons Logging(簡稱 JCL)的支持和集成。

Apache Commons Logging 是一個廣泛使用的日志 API,它提供了一種通用的日志記錄接口,允許開發者在他們的應用代碼中使用日志記錄,而不必關心底層的日志實現框架是什么

1.2、Spring-Jcl 模塊依賴

Spring-Jcl 主要依賴于 Spring-Core 模塊,因為它提供了 Spring 框架的基礎核心功能,并且需要依賴 Java 的日志 API,如 SLF4J 或 Log4j(具體取決于項目的日志實現)。

1.3、Spring-Jcl 模塊作用

Spring-Jcl 模塊的主要作用:

  • 作為 Spring 框架的日志適配層,提供對不同日志實現的支持。
  • 提供自動檢測和綁定不同日志框架的能力,避免手動適配。
  • 允許開發者在不改變代碼的情況下,靈活切換日志實現,如從 Log4j 遷移到 SLF4J。

2、Spring WebSocket 案例

在 Spring 傳統項目中,我們可以使用 Spring-Jcl 作為日志抽象層,并結合 Log4j 作為日志實現。

2.1、項目依賴

pom.xml 文件中添加以下依賴:

<dependencies><!-- Spring 核心模塊 --><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>5.3.30</version></dependency><!-- Spring-Jcl 日志模塊 --><dependency><groupId>org.springframework</groupId><artifactId>spring-jcl</artifactId><version>5.3.30</version></dependency><!-- Log4j 作為日志實現 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>
</dependencies>
2.2、配置 Log4j

src/main/resources 目錄下創建 log4j.properties 文件,配置日志級別和日志輸出方式:

# 設置日志級別
log4j.rootLogger=INFO, stdout, file# 控制臺輸出
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1} - %m%n# 文件輸出
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=app.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1} - %m%n
2.3、編寫日志示例

創建 LoggingService.java 并使用 Spring-Jcl 進行日志記錄:

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;public class LoggingService {// 使用 Spring-Jcl 提供的 LogFactory 獲取日志對象private static final Log logger = LogFactory.getLog(LoggingService.class);public void performTask() {logger.info("執行任務中...");try {int result = 10 / 0; // 模擬異常} catch (Exception e) {logger.error("發生錯誤:", e);}logger.debug("任務執行完畢!");}public static void main(String[] args) {LoggingService service = new LoggingService();service.performTask();}
}
2.4、運行結果

運行 LoggingService,控制臺會輸出日志信息,同時 app.log 文件中也會記錄日志:

2025-04-03 12:00:00 [main] INFO  LoggingService - 執行任務中...
2025-04-03 12:00:00 [main] ERROR LoggingService - 發生錯誤:
java.lang.ArithmeticException: / by zeroat LoggingService.performTask(LoggingService.java:11)at LoggingService.main(LoggingService.java:19)
2025-04-03 12:00:00 [main] DEBUG LoggingService - 任務執行完畢!

X、后記

通過本篇文章,我們詳細解析了 Spring-Jcl 模塊的核心概念、依賴關系及其作用,并通過 Log4j 案例演示了如何在 傳統 Spring 項目 中集成日志管理。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/74412.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/74412.shtml
英文地址,請注明出處:http://en.pswp.cn/web/74412.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Hadoop集群---運維管理和技巧

一. daemon 守護進程管理 1. NameNode守護進程管理 hadoop-daemon.sh start namenode 2. DataNode守護進程管理 hadoop-daemon.sh start datanode 3. ResourceManager守護進程管理 yarn-daemon.sh start resourcemanager 4. NodeManager守護進程管理 yarn-daemon.sh st…

ngx_log_init

定義在 src\core\ngx_log.c ngx_log_t * ngx_log_init(u_char *prefix, u_char *error_log) {u_char *p, *name;size_t nlen, plen;ngx_log.file &ngx_log_file;ngx_log.log_level NGX_LOG_NOTICE;if (error_log NULL) {error_log (u_char *) NGX_ERROR_LOG_PATH;}…

網絡華為HCIA+HCIP 策略路由,雙點雙向

目錄 路由策略&#xff0c;策略路由 策略路由優勢 策略路由分類 接口策略路由 雙點雙向 雙點雙向路由引入特點: 聯系 路由回灌和環路問題 路由策略&#xff0c;策略路由 路由策略:是對路由條目進行控制&#xff0c;通過控制路由條目影響報文的轉發路徑&#xff0c;即路…

水下成像機理分析

一般情況下, 水下環境泛指浸入到人工水體 (如水庫、人工湖等)或自然水體(如海洋、河流、湖 泊、含水層等)中的區域。在水下環境中所拍攝 的圖像由于普遍受到光照、波長、水中懸浮顆粒物 等因素的影響&#xff0c;導致生成的水下圖像出現模糊、退 化、偏色等現象&#xff0c;圖像…

MySQL的數據目錄以及日志

1.MySQL數據目錄 MySQL服務器的管理信息、業務數據、?志?件、磁盤緩沖?件默認存儲在數據?錄下.數據目錄保存了我們用戶的信息,以及我們創建的數據庫和表的數據.維護了日志文件等.mysqld主要操作的就是我們的數據目錄. 如何查看數據目錄: ll /var/lib/mysql#ll 是查看指令 …

論文閱讀:Dual Anchor Graph Fuzzy Clustering for Multiview Data

論文地址:Dual Anchor Graph Fuzzy Clustering for Multiview Data | IEEE Journals & Magazine | IEEE Xplore 代碼地址&#xff1a;https://github.com/BBKing49/DAG_FC 摘要 多視角錨圖聚類近年來成為一個重要的研究領域&#xff0c;催生了多個高效的方法。然而&#…

32f4,串口1,usart.c.h2025

usart.c #include "sys.h" #include "usart.h" #include "led.h" // #include "stdlib.h" #include "stdarg.h" #include "stdio.h" //加入以下代碼,支持printf函數,而不需要選擇use MicroLIB #if 1#pragma…

C語言:一組位操作宏

解析協議時&#xff0c;取得位域的值是一種常見操作&#xff0c;這些宏可以輔助我們工作。 /* ** 將x的第n位置1 ** ** x 0x00000000 ** BIT_SET(x, 7) 0x00000080 */ #define BIT_SET(x, n) ((x) | (1 << (n)))/* ** 將x的第n位置為0 ** ** x 0x00000080 ** …

記一個使用BigDecimal所有類型變為整數的問題

場景 通過 Excel 導入數據&#xff0c;數據中包含金額。數據庫類型 decimal(18, 6) 問題 Excel 導入后所有的金額列都被四舍五入。經過測試&#xff0c;只有數據有整數時所有數據才會被四舍五入&#xff0c;全部為浮點類型沒有問題。 解決 強制設置小數位數 // RoundingM…

nodejs、socket.io、express + 實時線上聊天系統(自用筆記)

留個鏈接給自己參考用&#xff1a; socket.io官方文檔&#xff1a;介紹 | Socket.IO nodejs基礎語法&#xff1a;大前端技能講解&#xff1a;NodeJS、Npm、Es6、Webpack_nodejs webpack-CSDN博客 socket.io教學&#xff1a;半小時學會socket.io【中英字幕】Learn Socket.Io …

配置網絡編輯器

網絡斷開的原因 1.由于網絡未連接的情況 解決方法 方法1&#xff1a;檢查網卡配置 cd /etc/syscongfig/network_scripts vi ifcfg_ens31 方法2&#xff1a;打開虛擬機編輯--- 虛擬網絡編輯器 查看ip地址是否在可用的網段范圍內 修改后重啟網絡 systemctl restart netwo…

vscode代碼片段的設置與使用

在 Visual Studio Code (VS Code) 中&#xff0c;可以通過自定義**代碼片段&#xff08;Snippets&#xff09;**快速插入常用代碼模板。以下是詳細設置步驟&#xff1a; 步驟 1&#xff1a;打開代碼片段設置 按下快捷鍵 Ctrl Shift P&#xff08;Windows/Linux&#xff09;或…

基于S函數的simulink仿真

基于S函數的simulink仿真 S函數可以用計算機語言來描述動態系統。在控制系統設計中&#xff0c;S函數可以用來描述控制算法、自適應算法和模型動力學方程。 S函數中使用文本方式輸入公式和方程&#xff0c;適合復雜動態系統的數學描述&#xff0c;并且在仿真過程中可以對仿真…

做題記錄:和為K的子數組

來自leetcode 560 前言 自己只會暴力&#xff0c;這里就是記錄一下前綴和哈希表的做法&#xff0c;來自靈神的前綴和哈希表&#xff1a;從兩次遍歷到一次遍歷&#xff0c;附變形題 正文 首先&#xff0c;這道題無法使用滑動窗口&#xff0c;因為滑動窗口需要滿足單調性&am…

淺淺嘗試Numpy的函數:

1.numpy.empty: numpy.empty方法用來創建一個指定形狀&#xff08;shape&#xff09;&#xff0c;數據類型&#xff08;dtype&#xff09;且未被初始化的數組&#xff1a; numpy.empty(shape,dtype float,order C) 參數說明&#xff1a; shape:數組形狀。 dtype:數據類型&am…

IM基本設計思路與有序ID的重要性

文章目錄 概要問題解析思考問題數據基礎讀取寫入總結 概要 說起IM程序我們都不陌生&#xff0c;本篇文章我們就為如何實現一個IM做一個簡單的整體方案設計以及基本的數據結構 問題解析 我們先不上一大堆牛逼哄哄的中間件。 我們先從實現角度&#xff0c;來講講設計思路。 從…

數據結構學習

鏈表 單鏈表 頭插 將x插到下標是k的點后面 將下標是k的點后面的點刪掉 代碼 // head 表示頭結點的下標 // e[i] 表示節點i的值 // ne[i] 表示節點i的next指針是多少 // idx 存儲當前已經用到了哪個點// 初始化 void init() {head -1;idx 0; }// 將x插到頭結點 void add_to_…

0.DJI-PSDK開發準備及資料說明(基于DJI經緯M300RTK和M350RTK無人機上使用)

0.DJI-PSDK開發準備及資料說明&#xff08;基于DJI經緯M300RTK和M350RTK無人機上使用&#xff09; 【資料名稱】 DJI經緯M300RTK和M350RTK無人機二次開發資料包。資料包在最下方的百度網盤 一、引言 在進行大疆無人機負載開發的過程中&#xff0c;我整理出一系列有價值的資…

Linux內核TCP/IP協議棧中的設計模式:從面向對象到系統級軟件的跨界實踐

引言 設計模式(Design Patterns)自GoF(Gang of Four)在1994年提出以來,已成為軟件工程領域的核心概念。盡管其經典定義基于面向對象編程(OOP),但設計模式的本質是解決復雜問題的經驗總結,而非局限于特定編程范式。本文以Linux內核的TCP/IP協議棧為例,探討設計模式在…

第十四屆藍橋杯大賽軟件賽省賽C/C++ 大學 B 組(部分題解)

文章目錄 前言日期統計題意&#xff1a; 冶煉金屬題意&#xff1a; 島嶼個數題意&#xff1a; 子串簡寫題意&#xff1a; 整數刪除題意&#xff1a; 總結 前言 一年一度的&#x1f3c0;杯馬上就要開始了&#xff0c;為了取得更好的成績&#xff0c;好名字寫了下前年2023年藍橋…