你真的懂java的日志系統(tǒng)嗎
一、背景
在java的開發(fā)中,使用最多也繞不過去的一個話題就是日志,在程序中除了業(yè)務代碼外,使用最多的就是打印日志。經常聽到的這樣一句話就是“打個日志調試下”,沒錯在日常的開發(fā)、調試過程中打印日志是常干的一件事,同時系統(tǒng)正常運行過程中必要的日志打印也是必須的。
二、詳情
在筆者剛接觸java程序的時候,打印日志經常使用到到下面的代碼,
System.out.println("hello log");
我相信在不了解日志系統(tǒng)的前提下使用上述的方式是最多的,同時也是新手小白最常用的方式,筆者曾經也是使用最多的。那么除了上述的方式還有其他的方式嗎?答案是肯定的
2.1、java自帶的日志
在java的API中提供了一套日志打印的方法,java程序人員在設計之初已經想到了這方面的功能,所以從JDK1.4起提供了日志打印的API,只不過被大多數(shù)人忽略了。這套API在java.util.logging包下,使用該種方式不需要引任何的jar,只要在java環(huán)境下即可使用。
如上圖,是java提供的日志的一些類。使用方法類似下面的代碼,
public static Logger logger=Logger.getLogger(Test.class.toString()); logger.info("hello log");
注意Logger的路徑是java.util.logging.Logger。
2.2、log4j
log4j是apache的一個項目,其中又分為log4j1和log4j2,所謂log4j1指的就是其大版本號為1,不過log41在很早之前就已經停止更新了,源碼官網:https://github.com/apache/logging-log4j1
可以看的在2012年已經停止更新了,也就是說現(xiàn)在通常來說使用的log4j都是log4j2,更確切的說是log4j,為了準確期間,這里還是和之前的版本進行區(qū)分,使用log4j2的名字,log4j2是在log4j1基礎上的升級,并吸收了logback這個框架的優(yōu)秀之處且修復了其很多問題,可以說log4j2是一個優(yōu)秀的日志框架,其源碼官網:https://github.com/apache/logging-log4j2
官網:https://logging.apache.org/log4j/2.x/index.html
log4j2的maven依賴如下,引入log4j-api和log4j-core即可,
<dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.17.1</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.17.1</version> </dependency>
這里有個問題要注意,log4j1和log4j2的groupId是不一樣的,log4j1的是org.apache.log4j,log4j2的是org.apache.logging.log4j,帶來的變化就是在使用的過程中要注意引用的類的路徑,從路徑上可以確定是使用的log4j1.x還是log4j2.x,如果是org.apache.log4j開頭的包路徑那么是版本1的,是org.apache.logging.log4j開頭的是版本2的。
使用方式類似如下,
private static final Logger logger= LogManager.getLogger(); logger.info();
2.3、logback
logback是一個開源的日志框架,是log4j的作者為了代替log4j而開發(fā)的。logback包含三部分,logback-core、logback-classic、logback-access,logback-core是其他兩個模塊的核心,常用到的是logback-core+logback-classic。logback-access常和jetty和tomcat結合。
logback的groupId為ch.qos.logback,其maven依賴如下
<dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.2.10</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.2.10</version> </dependency> <!--平時用不到,可不引入--> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-access</artifactId> <version>1.2.10</version> </dependency>
使用方法可參考:https://www.jianshu.com/p/3e3b550920b3
其官網:https://logback.qos.ch/index.html
2.4、slf4j
slf4j不能稱之為一個日志框架,因為它僅僅提供了一系列的標準,提供一系列接口,但沒有實現(xiàn),采用的是門面模式。
其依賴為:
<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.36</version> </dependency>
上面便是slf4j的核心包。
注意:如果使用slf4j出現(xiàn)下面的日志
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
說明沒有日志實現(xiàn)框架,slf4j自己實現(xiàn)了一個日志框架,可以加上下面的依賴
<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-simple</artifactId> <version>1.7.36</version> </dependency>
slf4j可以和其他具體的日志實現(xiàn)框架進行結合使用,如下
上圖是一個slf4j和其他日志框架結合的圖形展示,
slf4j+logback
需要slf4j-api、logback-api、logback-classic三個包
slf4j+JDK日志
需要slf4j-api、slf4j-jdk14,其中slf4j-jdk14是slf4j和JDK日志結合的jar。
slf4j+log4j
需要slf4j+slf4j-log4j12
slf4j+JCL
需要slf4j、common-logging
其官網:https://www.slf4j.org/
2.5、JCL
JCL是Jakarta Commons Logging的簡寫,又叫Apache Commons Logging,提供的是一個 Java 的日志接口,同時兼顧輕量級和不依賴于具體的日志實現(xiàn)工具。它提供給中間件/日志工具開發(fā)者一個簡單的日志操作抽象,允許程序開發(fā)人員使用不同的具體日志實現(xiàn)工具。用戶被假定已熟悉某種日志實現(xiàn)工具的更高級別的細節(jié)。JCL提供的接口,對其它一些日志工具,包括Log4J, Avalon LogKit, and JDK 1.4等,進行了簡單的包裝,此接口更接近于Log4J和LogKit的實現(xiàn)。
其包為common-logging.jar包含了所有的功能,還有其他另外兩個包common-logging-api、common-logging-adapters
官網:https://commons.apache.org/proper/commons-logging/guide.html
三、總結
本文簡單總結了java中常用的日志,其中slf4j和JCL是日志的接口,又都進行了簡單實現(xiàn),既可以自己單獨使用,又可以和其他實現(xiàn)日志框架結合使用,如,log4j、logback、JDK logging等。
到此這篇關于java日志系統(tǒng)的文章就介紹到這了,更多相關java日志系統(tǒng)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java通過jacob實現(xiàn)office在線預覽功能
這篇文章主要為大家詳細介紹了java通過jacob實現(xiàn)office在線預覽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08springboot?使用websocket技術主動給前端發(fā)送消息的實現(xiàn)
這篇文章主要介紹了springboot?使用websocket技術主動給前端發(fā)送消息的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12Java實現(xiàn)AOP功能的封裝與配置的小框架實例代碼
這篇文章主要介紹了Java實現(xiàn)AOP功能的封裝與配置的小框架實例代碼,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02解決JAVA8 Collectors.toMap value為null報錯的問題
這篇文章主要介紹了解決JAVA8 Collectors.toMap value為null報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01