国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術(shù)|正則表達(dá)式|

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

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

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

下面小編就為大家?guī)砝仙U凩og4j和Log4j2的區(qū)別(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

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

log4j是Apache的一個(gè)開源項(xiàng)目,我們不去考究它的起源時(shí)間,但是據(jù)我了解,log4j 1已經(jīng)不再更新了。

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

1、配置文件類型

log4j是通過一個(gè).properties的文件作為主配置文件的,而現(xiàn)在的log4j 2則已經(jīng)棄用了這種方式,采用的是.xml,.json或者.jsn這種方式來做,可能這也是技術(shù)發(fā)展的一個(gè)必然性,畢竟properties文件的可閱讀性真的是有點(diǎn)差。

2、核心JAR包

log4j只需要引入一個(gè)jar包即可,

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

而log4j 2則是需要2個(gè)核心

?
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>

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

3、文件渲染

log4j想要生效,我們需要在web.xml中進(jìn)行配置,

?
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的配置文件和定義一個(gè)掃描器,這樣可以隨心所欲的放置log4j配置文件。

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

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

4、Log調(diào)用

log4j和log4j2調(diào)用都是很簡(jiǎn)單的。

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、配置文件方式

最關(guān)鍵的最大的不同,那就是配置文件的區(qū)別了,大家具體使用的時(shí)候再根據(jù)你的情況進(jìn)行配置就行了。

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>
<!--   這個(gè)輸出控制臺(tái)的配置 -->
  <Console name="Console" target="SYSTEM_OUT">
<!--    控制臺(tái)只輸出level及以上級(jí)別的信息(onMatch),其他的直接拒絕(onMismatch) -->
   <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
<!--    這個(gè)都知道是輸出日志的格式 -->
   <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
  </Console>
 
<!--   文件會(huì)打印出所有信息,這個(gè)log每次運(yùn)行程序會(huì)自動(dòng)清空,由append屬性決定,這個(gè)也挺有用的,適合臨時(shí)測(cè)試用 -->
<!--   append為TRUE表示消息增加到指定文件中,false表示消息覆蓋指定的文件內(nèi)容,默認(rèn)值是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,可以有選擇的輸出某個(gè)級(jí)別以上的類別 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>
 
<!--   這個(gè)會(huì)打印出所有的信息,每次大小超過size,則這size大小的日志會(huì)自動(dòng)存入按年份-月份建立的文件夾下面并進(jìn)行壓縮,作為存檔 -->
  <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才會(huì)生效 -->
 <loggers>
<!--   建立一個(gè)默認(rèn)的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的區(qū)別(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 在线欧美亚洲 | 久久中文字幕一区 | 国产特级毛片aaaaaa毛片 | 成人免费色 | 中文字幕在线电影观看 | 黄色a视频| 精品视频在线播放 | 久久久精彩| 精品一区二区三区中文字幕 | 亚洲欧美日韩精品久久亚洲区 | 激情欧美一区二区三区中文字幕 | 日韩精品久久久 | 日本视频免费观看 | 欧美一级二级三级视频 | 免费成人在线电影 | 中文字幕亚洲欧美 | 福利片中文字幕 | 亚州av在线| 99在线免费观看 | 我和我的祖国电影在线观看免费版高清 | 九九久久免费 | 精品视频| 亚洲第一视频 | 午夜视频网站 | 国产成人一区 | 亚洲国产精品无卡做爰天天 | 日韩一区中文字幕 | www.888www看片 | 国产 日韩 欧美 中文 在线播放 | 欧洲一级毛片 | 精品无码久久久久久国产 | 欧美天堂一区二区三区 | 日韩在线一区二区 | 依人网站 | 成人在线观看免费爱爱 | 欧美成视频 | 精品国产乱码久久久久久1区2区 | 黑人精品 | 免费成人高清在线视频 | 国产高清不卡在线 | 色花av|