在Java中使用日志框架log4j的方法
日志就是記錄程序的運(yùn)行軌跡,方便快速定位問(wèn)題
如果用System.out.println(),信息是打印在控制臺(tái)。等到產(chǎn)品上線后沒(méi)有控制臺(tái),如果有報(bào)錯(cuò)信息,根本不知道去哪里看,就不知道是哪里出錯(cuò)。
而且開(kāi)發(fā)的時(shí)候希望打印輸出的內(nèi)容多。方便排查,上線后只希望打印容易出錯(cuò)的部分。System.out.println()滿足不了這個(gè)需求
而日志框架可以讓錯(cuò)誤信息輸出到多個(gè)指定文件,不同的文件有不同的輸出內(nèi)容。方便排錯(cuò),定位錯(cuò)誤
一、log4j介紹
Log4j有三個(gè)主要的組件/對(duì)象:Loggers(記錄器),Appenders (輸出源)和Layouts(布局)。這里可簡(jiǎn)單理解為日志類(lèi)別,日志要輸出的地方和日志以何種形式輸出。
每條日志語(yǔ)句都要設(shè)置一個(gè)等級(jí)(DEBUG、INFO、WARN、ERROR和FATAL)。
其中DEBUG < INFO < WARN < ERROR < FATAL。fatal等級(jí)最高
對(duì)應(yīng)調(diào)試信息 一般信息 警告信息 錯(cuò)誤信息 嚴(yán)重錯(cuò)誤信息
1、Loggers
在設(shè)置日志輸出位置的時(shí)候,會(huì)給那個(gè)位置設(shè)置一個(gè)級(jí)別,只有大于等于那個(gè)級(jí)別的日志才會(huì)打印輸出到指定位置。
例如:某個(gè)Loggers(日志輸出位置的等級(jí)記錄器)級(jí)別設(shè)定為INFO,則INFO、WARN、ERROR和FATAL級(jí)別的日志信息都會(huì)輸出到那個(gè)文件,而級(jí)別比INFO低的DEBUG則不會(huì)輸出。
2、Appenders
禁用和使用日志請(qǐng)求只是Log4j的基本功能,Log4j日志系統(tǒng)還提供許多強(qiáng)大的功能,比如允許把日志輸出到不同的地方,如控制臺(tái)(Console)、文件(Files)等,可以根據(jù)天數(shù)或者文件大小產(chǎn)生新的文件,可以以流的形式發(fā)送到其它地方等等。
常使用的類(lèi)如下:
org.apache.log4j.ConsoleAppender(控制臺(tái))
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天產(chǎn)生一個(gè)日志文件)
org.apache.log4j.RollingFileAppender(文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件)
org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方)
基本上可以滿足我們的日常需求,當(dāng)然如果你的需求比較特殊,可以自己實(shí)現(xiàn)Appender輸出路徑。只需要定義一個(gè)類(lèi),實(shí)現(xiàn)Appender接口就可以了。Appender接口中定義了一系列記錄日志的方法,按照自己的規(guī)則實(shí)現(xiàn)這些方法即可
3、Layouts
用戶可以根據(jù)自己的喜好格式化自己的日志輸出,Layouts提供四種日志輸出樣式,如根據(jù)HTML樣式、自由指定樣式、包含日志級(jí)別與信息的樣式和包含日志時(shí)間、線程、類(lèi)別等信息的樣式。
常使用的類(lèi)如下:
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.PatternLayout(可以靈活地指定布局模式)
org.apache.log4j.SimpleLayout(包含日志信息的級(jí)別和信息字符串)
org.apache.log4j.TTCCLayout(包含日志產(chǎn)生的時(shí)間、線程、類(lèi)別等信息)
二、使用
在實(shí)際應(yīng)用中,要使Log4j在系統(tǒng)中運(yùn)行必須事先設(shè)定配置文件。配置文件事實(shí)上也就是對(duì)Logger、Appender及Layout進(jìn)行相應(yīng)設(shè)定。Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是properties屬性文件,配置文件詳解在下面使用部分說(shuō)明
我是用maven創(chuàng)建項(xiàng)目
1、導(dǎo)包

在pom.xml
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
2、創(chuàng)建配置文件
日志配置文件:log4j.properties文件或者logback.xml。
我用的是log4j.properties
在普通的se項(xiàng)目中放到src同級(jí)目錄下,maven項(xiàng)目中放到src/main/resources目錄下
### 日志的輸出級(jí)別是dubug,輸出位置名字叫stdout,D
log4j.rootLogger = debug,stdout,D
### 輸出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
#用特定格式輸出日志
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#下面是規(guī)定好的格式,有點(diǎn)像c語(yǔ)言printf的%d,%m是輸出代碼中指定的消息的占位符
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
### 輸出warn 級(jí)別以上的日志到文件里
# 文件位置為:D:/logs/error.log4j
log4j.appender.D = org.apache.log4j.FileAppender
log4j.appender.D.File = D:/logs/error.log4j
log4j.appender.D.Append = true
log4j.appender.D.Threshold = warn
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
3、使用
在代碼中使用Log4j
public class Test {
@org.junit.Test
public void testLog(){
//1、獲取日志記錄器,這個(gè)記錄器將負(fù)責(zé)控制日志信息
//Name一般取當(dāng)前類(lèi)的名字
Logger logger = Logger.getLogger(Test.class);
//直接使用日志記錄器,打印日志
logger.debug("dubug級(jí)別");
logger.error("error級(jí)別");
}
}
最后結(jié)果:
控制臺(tái)輸出

磁盤(pán)中的文件輸出

-------------------------------下面的太復(fù)雜------------------------------------

http://www.dhdzp.com/article/134950.htm
http://www.dhdzp.com/article/121581.htm
###配置日志根Logger #第一參數(shù)是日志輸出級(jí)別,這里是一個(gè)全局級(jí)別,只要它指定了error,下面不管設(shè)置什么比它的低級(jí)別都會(huì)失效,所以一般指定dubug #后面幾個(gè)參數(shù)都是日志輸出的位置,多個(gè)輸出路徑用,隔開(kāi);隨便起名只是一個(gè)代號(hào) log4j.rootLogger=DEBUG,out1,out2,out3,out4 #ERROR 為嚴(yán)重錯(cuò)誤 主要是程序的錯(cuò)誤 #WARN 為一般警告,比如session丟失 #INFO 為一般要顯示的信息,比如登錄登出 #DEBUG 為程序的調(diào)試信息 #表示Logger的內(nèi)容不會(huì)在父Logger的appender里輸出,默認(rèn)為true。 (?可能是這樣,要輸出日志時(shí),得先創(chuàng)建一個(gè)Logger對(duì)象,用Logger對(duì)象打印,如果這里是true,日志內(nèi)容不僅會(huì)出現(xiàn)在當(dāng)前配置的日志文件里,還會(huì)出現(xiàn)在父類(lèi)的日志文件里) log4j.additivity.org.apache=false
下面的輸出位置名字分別是 out1,out2,out3,out4
###配置日志信息輸出目的地Appender,appender后面的參數(shù)對(duì)應(yīng)log4j.rootLogger的位置名稱 log4j.appender.out1=org.apache.log4j.ConsoleAppender #打印到控制臺(tái) log4j.appender.out1.Threshold=DEBUG #指定日志信息的最低輸出級(jí)別,默認(rèn)為DEBUG。 log4j.appender.out1.ImmediateFlush=true #表示所有消息都會(huì)被立即輸出,設(shè)為false則不輸出,默認(rèn)值是true。 log4j.appender.out1.Target=System.err #默認(rèn)值是System.out。?不知道是什么 log4j.appender.out1.layout=org.apache.log4j.PatternLayout #可以靈活地指定布局模式 log4j.appender.out1.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n #布局格式 # 日志文件(logFile) log4j.appender.logFile=org.apache.log4j.FileAppender log4j.appender.logFile.Threshold=DEBUG log4j.appender.logFile.ImmediateFlush=true log4j.appender.logFile.Append=true log4j.appender.logFile.File=D:/logs/log.log4j log4j.appender.logFile.layout=org.apache.log4j.PatternLayout log4j.appender.logFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n ### 輸出到日志文件 ### #org.apache.log4j.ConsoleAppender #org.apache.log4j.FileAppender(文件) #org.apache.log4j.DailyRollingFileAppender #org.apache.log4j.RollingFileAppender(文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件) #org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方) #log4j.appender.error.Target=System.out
logback.xml可以看:http://www.dhdzp.com/article/207994.htm
使用
在不同環(huán)境使用日志框架:http://www.dhdzp.com/article/74475.htm
http://www.dhdzp.com/article/207994.htm
http://www.dhdzp.com/article/197121.htm
到此這篇關(guān)于在Java中使用日志框架log4j的文章就介紹到這了,更多相關(guān)Java日志框架log4j內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
通過(guò)Spring自定義NamespaceHandler實(shí)現(xiàn)命名空間解析(推薦)
這篇文章主要介紹了通過(guò)Spring自定義NamespaceHandler實(shí)現(xiàn)命名空間解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
Spring @Async 注解異步調(diào)用失效的五種解決方案
加上了@Async 注解,期待它能異步執(zhí)行,結(jié)果發(fā)現(xiàn)它還是同步執(zhí)行的?更困惑的是,同樣的注解在其他地方卻能正常工作,這個(gè)問(wèn)題困擾了很多 Java 開(kāi)發(fā)者,尤其是當(dāng)你在同一個(gè)類(lèi)中調(diào)用帶有@Async 注解的方法時(shí),今天,我們就來(lái)深入解析這個(gè)問(wèn)題的原因,并提供多種實(shí)用的解決方案2025-05-05
Java實(shí)現(xiàn)二叉樹(shù)的示例代碼(遞歸&迭代)
二叉樹(shù)(Binary?tree)是樹(shù)形結(jié)構(gòu)的一個(gè)重要類(lèi)型。本文將利用Java語(yǔ)言實(shí)現(xiàn)二叉樹(shù),文中的示例代碼講解詳細(xì),需要的同學(xué)可以參考一下2022-03-03
Idea中maven無(wú)法下載依賴包問(wèn)題解決
用過(guò)idea開(kāi)發(fā)過(guò)項(xiàng)目的同學(xué),偶爾會(huì)遇到項(xiàng)目中有一些依賴沒(méi)法下載,或者依賴包已經(jīng)有項(xiàng)目卻無(wú)法掃到的問(wèn)題,本文就詳細(xì)的介紹了解決方法,感興趣的可以了解一下2020-08-08

