Apache Log4j是一個基於Java的日誌記錄工具,它的日誌級別按下面順序遞減:html
級別 | 描述 |
---|---|
OFF | 最高級別,用於關閉日誌記錄。 |
FATAL | 將致使應用程序提早終止的嚴重錯誤的信息將當即呈如今日誌上。 |
ERROR | 將其餘運行時錯誤或意外狀況的信息呈如今日誌上。 |
WARN | 使用已過期的API,API的濫用,潛在錯誤,其餘不良的或意外的運行時的情況(但不必定是錯誤的) |
INFO | 一些感興趣的運行時事件(啓動/關閉 |
DEBUG | 一些詳細信息,查看程序的運行狀態 |
TRACE | 最詳細的信息。通常這些信息只記錄到日誌文件中。 |
下面介紹如何在java項目中如何使用Log4j。java
<dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> </dependencies>
其配置文件名爲log4j.properties,須要手動在java/resources下建立,若是建在其餘位置,idea這個工具將沒法識別(若是沒法識別後面會介紹怎麼解決)。下面介紹該配置文件的幾個基本配置項。apache
形式 | 描述 |
---|---|
org.apache.log4j.ConsoleAppender | 控制檯 |
org.apache.log4j.FileAppender | 文件 |
org.apache.log4j.DailyRollingFileAppender | 天天產生一個日誌文件 |
org.apache.log4j.RollingFileAppender | 文件大小到達指定尺寸的時候產生一個新的文件 |
org.apache.log4j.WriterAppender | 將日誌信息以流格式發送到任意指定的地方 |
形式 | 描述 |
---|---|
org.apache.log4j.HTMLLayout | 以HTML表格形式佈局 |
org.apache.log4j.PatternLayout | 能夠靈活地指定佈局模式 |
org.apache.log4j.SimpleLayout | 包含日誌信息的級別和信息字符串 |
org.apache.log4j.TTCCLayout | 包含日誌產生的時間、線程、類別等等信息 |
採用相似C語言中的printf函數的打印格式格式化日誌信息app
形式 | 描述 |
---|---|
%d | 輸出日誌時間點的日期或時間,能夠在其後指定格式,好比:%d{yyy MMM dd HH:mm:ss , SSS} |
%t | 輸出產生該日誌事件的線程名 |
%p | 優先級 DEBUG/INFO/ERROR |
%c | 所屬類的全名(包括包名) |
%l | 發生的位置,在某個類的某行 |
%m | 輸出代碼中指定的訊息,如log(message)中的message |
%n | 輸出一個換行符號 |
案例使用以下的配置信息:maven
### set log levels ### log4j.rootLogger = DEBUG,Console,File ### 輸出到控制檯 ### log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.Target=System.out log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}]-%l:%m%n ### 輸出到日誌文件 ### log4j.appender.File=org.apache.log4j.RollingFileAppender log4j.appender.File.File=${project}src\\main\\resources\\app.log log4j.appender.File.MaxFileSize=10MB log4j.appender.File.Threshold=ALL log4j.appender.File.layout=org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
配置完上面信息後就能夠建立一個Java文件去測試日誌的文件的使用了。ide
package com.gqx.test; import org.apache.log4j.Logger; public class Hello { private static Logger log = Logger.getLogger(Hello.class.getClass()); public static void main(String[] args) { log.debug("debug..."); log.error("error..."); } }
結果如圖左側(左上是控制檯的log,左下是app.log文件的log),其中整個工程的佈局如圖右側:函數
過程當中可能出現下面的問題:工具
log4j:WARN No appenders could be found for logger (java.lang.Class).
log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
這個實際上是IDE(Idea)找不到log4j的properties文件,有些博客說能夠去project_structure去改配置,嘗試了一下惋惜沒有用,但發現了能夠在程序中經過代碼去指定properties文件的位置,若是出現了 上面的錯誤,能夠改爲以下形式:佈局
package com.gqx.test; import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; public class Hello { private static Logger log = Logger.getLogger(Hello.class.getClass()); public static void main(String[] args) { //獲取當前項目的根目錄 String relativelyPath=System.getProperty("user.dir"); PropertyConfigurator.configure(relativelyPath+ "\\src\\main\\resources\\log4j.properties"); log.debug("debug..."); log.error("error..."); } }
原文出處:https://www.cnblogs.com/helloworldcode/p/11699105.html測試