激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|

服務器之家 - 編程語言 - JAVA教程 - 老生常談Log4j和Log4j2的區別(推薦)

老生常談Log4j和Log4j2的區別(推薦)

2020-09-20 13:49Java之家 JAVA教程

下面小編就為大家帶來老生常談Log4j和Log4j2的區別(推薦)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

相信很多程序猿朋友對log4j都很熟悉,log4j可以說是陪伴了絕大多數的朋友開啟的編程。我不知道log4j之前是用什么,至少在我的生涯中,是log4j帶我開啟的日志時代。

log4j是Apache的一個開源項目,我們不去考究它的起源時間,但是據我了解,log4j 1已經不再更新了。

回顧log4j,曾給我們留下了多少的回憶,我記得早些年,那時候mybatis還是叫ibatis的時候,我為了配置ibatis控制臺打印日志,糾結了多少個夜晚,最后配置出來時的那種喜悅感。廢話不多說,下面我就以列舉的方式來淺談log4j和log4j 2的不同之處。

1、配置文件類型

log4j是通過一個.properties的文件作為主配置文件的,而現在的log4j 2則已經棄用了這種方式,采用的是.xml,.json或者.jsn這種方式來做,可能這也是技術發展的一個必然性,畢竟properties文件的可閱讀性真的是有點差。

2、核心JAR包

log4j只需要引入一個jar包即可,

?
1
2
3
4
5
<dependency>
 <groupId>log4j</groupId>
 <artifactId>log4j</artifactId>
 <version>1.2.17</version>
</dependency>

而log4j 2則是需要2個核心

?
1
2
3
4
5
6
7
8
9
10
<dependency>
 <groupId>org.apache.logging.log4j</groupId>
 <artifactId>log4j-core</artifactId>
 <version>2.5</version>
</dependency>
<dependency>
 <groupId>org.apache.logging.log4j</groupId>
 <artifactId>log4j-api</artifactId>
 <version>2.5</version>
</dependency>

大家發現沒,log4j和log4j 2的包路徑是不同的,Apache為了區分,包路徑都更新了,這樣大家甚至可以在一個項目中使用2個版本的日志輸出哦!(不過我想你們沒有那么調皮吧,嘿嘿)

3、文件渲染

log4j想要生效,我們需要在web.xml中進行配置,

?
1
2
3
4
5
6
7
8
9
<listener>
 <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener> <context-param>
 <param-name>log4jConfigLocation</param-name>
 <param-value>classpath:config/log4j.properties</param-value>
 </context-param>
 <context-param>
 <param-name>log4jRefreshInterval</param-name>
 <param-value>60000</param-value>

這段配置目的在于告訴工程去哪加載log4j的配置文件和定義一個掃描器,這樣可以隨心所欲的放置log4j配置文件。

log4j2就比較簡單,以maven工程為例,我們只需要把log4j2.xml放到工程resource目錄下就行了。大家記住一個細節點,是log4j2.xml,而不是log4j.xml,xml名字少個2都不行!!

•喜歡做學問的小伙伴,有興趣可以去研究下,照我估計應該是在log4j2的包里面配置死了,而且大家可以嘗試下怎么自定義log4j2.xml的位置。

4、Log調用

log4j和log4j2調用都是很簡單的。

log4j:

?
1
2
import org.apache.log4j.Logger;
private final Logger LOGGER = Logger.getLogger(Test.class.getName());

log4j2:

?
1
2
3
4
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
private static Logger logger = LogManager.getLogger(Test.class.getName());

5、配置文件方式

最關鍵的最大的不同,那就是配置文件的區別了,大家具體使用的時候再根據你的情況進行配置就行了。

log4j2 例子如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<?xml version="1.0" encoding="UTF-8"?>
<configuration status="error">
<!--  先定義所有的appender -->
 <appenders>
<!--   這個輸出控制臺的配置 -->
  <Console name="Console" target="SYSTEM_OUT">
<!--    控制臺只輸出level及以上級別的信息(onMatch),其他的直接拒絕(onMismatch) -->
   <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
<!--    這個都知道是輸出日志的格式 -->
   <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
  </Console>
 
<!--   文件會打印出所有信息,這個log每次運行程序會自動清空,由append屬性決定,這個也挺有用的,適合臨時測試用 -->
<!--   append為TRUE表示消息增加到指定文件中,false表示消息覆蓋指定的文件內容,默認值是true -->
  <File name="log" fileName="log/test.log" append="false">
   <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
  </File>
 
<!--   添加過濾器ThresholdFilter,可以有選擇的輸出某個級別以上的類別 onMatch="ACCEPT" onMismatch="DENY"意思是匹配就接受,否則直接拒絕 -->
  <File name="ERROR" fileName="logs/error.log">
   <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
   <PatternLayout pattern="%d{yyyy.MM.dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
  </File>
 
<!--   這個會打印出所有的信息,每次大小超過size,則這size大小的日志會自動存入按年份-月份建立的文件夾下面并進行壓縮,作為存檔 -->
  <RollingFile name="RollingFile" fileName="logs/web.log"
      filePattern="logs/$${date:yyyy-MM}/web-%d{MM-dd-yyyy}-%i.log.gz">
   <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
   <SizeBasedTriggeringPolicy size="2MB"/>
  </RollingFile>
 </appenders>
 
<!--  然后定義logger,只有定義了logger并引入的appender,appender才會生效 -->
 <loggers>
<!--   建立一個默認的root的logger -->
  <root level="trace">
   <appender-ref ref="RollingFile"/>
   <appender-ref ref="Console"/>
   <appender-ref ref="ERROR" />
   <appender-ref ref="log"/>
  </root>
 
 </loggers>
</configuration>

以上這篇老生常談Log4j和Log4j2的區別(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲精品在线观看免费 | 91精品国产九九九久久久亚洲 | 涩涩伊人| 视频精品一区 | 在线观看中文字幕国产 | 国产精品久久久乱弄 | 精品成人免费一区二区在线播放 | 亚洲片在线观看 | 久久视讯 | 爽爽视频免费看 | 久操中文 | 91成人天堂久久成人 | 极品美女一级毛片 | 欧美一级做一级爱a做片性 久久久资源网 | 91短视频在线 | 国产成人在线观看网站 | 999久久久国产999久久久 | 性猛aa久久久 | 日本一区二区视频在线观看 | 欧美一区二区三区久久综合 | 一区在线视频 | 国产91丝袜在线播放 | 激情夜色 | 蜜桃网站在线 | 久啪视频 | 欧美成人高清视频 | 蜜桃91丨九色丨蝌蚪91桃色 | 97中文 | 久久精品久久久久 | 91看片在线播放 | 最污网站| 爱福利视频 | 美女黄影院 | 欧美成人黄色小视频 | 91成人在线免费视频 | 国产精品久久久久久久四虎电影 | 久久久久久久久久久久久久av | 视频一区二区不卡 | 国产成人在线免费视频 | 在线成人一区二区 | 在线观看日韩中文字幕 |