log4j教程
- 1. 簡介
- 2. 安裝
- 3. log4j基本概念
-
- 3.1. Logger
- 3.2. Appender
-
- 3.2.1. 使用ConsoleAppender
- 3.2.2. 使用FileAppender
- 3.2.3. 使用WriterAppender
- 3.3. Layout
- 3.4. 基本示例
-
- 3.4.1. SimpleLayout和FileAppender
- 3.4.2. HTMLLayout和WriterAppender
- 3.4.3. PatternLayout和ConsoleAppender
為了使用我們即將要安裝的日誌記錄工具,還必須要設定操作環境,只有這樣,工具才能知道從哪裡找到它所需要的資訊,並且作業系統知道從哪裡找到這個工具。那麼,怎樣做呢?實際上,它要求更改操作環境。
-
從 http://jakarta.apache.org/log4j/docs/download.html下載log4j發行版。
-
解壓存檔檔案到合適的目錄中。
-
新增檔案 dist/lib/log4j-1.2.6.jar 到 CLASSPATH 環境變數中。
日誌記錄器(Logger)是日誌處理的核心元件。log4j具有5種正常級別(Level)。 日誌記錄器(Logger)的可用級別Level (不包括自定義級別 Level), 以下內容就是摘自log4j API (http://jakarta.apache.org/log4j/docs/api/index.html):
-
static Level DEBUG
DEBUG Level指出細粒度資訊事件對除錯應用程式是非常有幫助的。
-
static Level INFO
INFO level表明 訊息在粗粒度級別上突出強調應用程式的執行過程。
-
static Level WARN
WARN level表明會出現潛在錯誤的情形。
-
static Level ERROR
ERROR level指出雖然發生錯誤事件,但仍然不影響系統的繼續執行。
-
static Level FATAL
FATAL level指出每個嚴重的錯誤事件將會導致應用程式的退出。
另外,還有兩個可用的特別的日誌記錄級別: (以下描述來自log4j APIhttp://jakarta.apache.org/log4j/docs/api/index.html):
-
static Level ALL
ALL Level是最低等級的,用於開啟所有日誌記錄。
-
static Level OFF
OFF Level是最高等級的,用於關閉所有日誌記錄。
日誌記錄器(Logger)的行為是分等級的。
有很多方法可以建立一個日誌記錄器(Logger),下面方法可以取回root日誌記錄器:
Logger logger = Logger.getRootLogger(); |
Logger logger = Logger.getLogger("MyLogger"); |
比較常用的用法,就是根據類名例項化一個靜態的全域性日誌記錄器:
static Logger logger = Logger.getLogger(test.class); |
所有這些建立的叫"logger"的日誌記錄器都可以用下面方法設定級別:
logger.setLevel((Level)Level.WARN); |
Appender 控制日誌怎樣輸出。下面列出一些可用的Appender(log4j API中所描述的http://jakarta.apache.org/log4j/docs/api/index.html):
-
ConsoleAppender:使用使用者指定的佈局(layout) 輸出日誌事件到System.out或者 System.err。預設的目標是System.out。
-
DailyRollingFileAppender 擴充套件FileAppender,因此多個日誌檔案可以以一個使用者選定的頻率進行迴圈日誌記錄。
-
FileAppender 把日誌事件寫入一個檔案
-
RollingFileAppender 擴充套件FileAppender備份容量達到一定大小的日誌檔案。
-
WriterAppender根據使用者的選擇把日誌事件寫入到Writer或者OutputStream。
-
SMTPAppender 當特定的日誌事件發生時,一般是指發生錯誤或者重大錯誤時,傳送一封郵件。
-
SocketAppender 給遠端日誌伺服器(通常是網路套接位元組點)傳送日誌事件(LoggingEvent)物件。
-
SocketHubAppender 給遠端日誌伺服器群組(通常是網路套接位元組點)傳送日誌事件(LoggingEvent)物件。
-
SyslogAppender給遠端非同步日誌記錄的後臺精靈程式(daemon)傳送訊息。
-
TelnetAppender 一個專用於向只讀網路套接字傳送訊息的log4j appender。
還可以實現 Appender 介面,建立以自己的方式進行日誌輸出的Appender。
ConsoleAppender appender = new ConsoleAppender(new PatternLayout()); |
FileAppender appender = null; try { appender = new FileAppender(new PatternLayout(),"filename"); } catch(Exception e) {} |
FileAppender(Layout layout, String filename) 例項化一個FileAppender並且開啟變數"filename"指定的檔案。 |
FileAppender(Layout layout, String filename, boolean append) 例項化一個FileAppender並且開啟變數"filename"指定的檔案。 |
WriterAppender appender = null; try { appender = new WriterAppender(new PatternLayout(),new FileOutputStream("filename")); } catch(Exception e) {} |
這裡是一個非常簡單的例子,程式實現了SimpleLayout和FileAppender:
import org.apache.log4j.Level; import org.apache.log4j.Logger; import org.apache.log4j.SimpleLayout; import org.apache.log4j.FileAppender; public class simpandfile { static Logger logger = Logger.getLogger(simpandfile.class); public static void main(String args[]) { SimpleLayout layout = new SimpleLayout(); FileAppender appender = null; try { appender = new FileAppender(layout,"output1.txt",false); } catch(Exception e) {} logger.addAppender(appender); logger.setLevel((Level) Level.DEBUG); logger.debug("Here is some DEBUG"); logger.info("Here is some INFO"); logger.warn("Here is some WARN"); logger.error("Here is some ERROR"); logger.fatal("Here is some FATAL"); } } |
你可以下載: simpandfile.java。 還可以檢視它的輸出: output1.txt.
這裡是一個非常簡單的例子,程式實現了 HTMLLayout和WriterAppender:
import java.io.*; import org.apache.log4j.Level; import org.apache.log4j.Logger; import org.apache.log4j.HTMLLayout; import org.apache.log4j.WriterAppender; public class htmlandwrite { static Logger logger = Logger.getLogger(htmlandwrite.class); public static void main(String args[]) { HTMLLayout layout = new HTMLLayout(); WriterAppender appender = null; try { FileOutputStream output = new FileOutputStream("output2.html"); appender = new WriterAppender(layout,output); } catch(Exception e) {} logger.addAppender(appender); logger.setLevel((Level) Level.DEBUG); logger.debug("Here is some DEBUG"); logger.info("Here is some INFO"); logger.warn("Here is some WARN"); logger.error("Here is some ERROR"); logger.fatal("Here is some FATAL"); } } |
你可以下載: simpandfile.java. 還可以檢視它的輸出:output1.txt.
這裡是一個非常簡單的例子,程式實現了PatternLayout和ConsoleAppender:
import org.apache.log4j.Level; import org.apache.log4j.Logger; import org.apache.log4j.PatternLayout; import org.apache.log4j.ConsoleAppender; public class consandpatt { static Logger logger = Logger.getLogger(consandpatt.class); public static void main(String args[]) { // Note, %n is newline String pattern = "Milliseconds since program start: %r %n"; pattern += "Classname of caller: %C %n"; pattern += "Date in ISO8601 format: %d{ISO8601} %n"; pattern += "Location of log event: %l %n"; pattern += "Message: %m %n %n"; PatternLayout layout = new PatternLayout(pattern); ConsoleAppender appender = new ConsoleAppender(layout); logger.addAppender(appender); logger.setLevel((Level) Level.DEBUG); logger.debug("Here is some DEBUG"); logger.info("Here is some INFO"); logger.warn("Here is some WARN"); logger.error("Here is some ERROR"); logger.fatal("Here is some FATAL"); } } |
你可以下載:simpandfile.java. 還可以檢視它的輸出: output2.txt.
Log4j經常與外部日誌檔案聯合使用,這樣很多可選項不必硬編碼在軟體中。使用外部配置檔案的優點就是修改可選項不需要重新編譯程式。唯一的缺點就是,由於用到io 指令,速度稍微有些減慢。
有兩個方法可以用來指定外部配置檔案:文字檔案或者XML檔案。既然現在所有事情都寫成XML檔案,那麼該教程就重點講解XML檔案方法,但是也包含相關文字檔案的例子。首先,看看下面的XML配置檔案示例:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="ConsoleAppender" class="org.apache.log4j.ConsoleAppender"> <layout class="org.apache.log4j.SimpleLayout"/> </appender> <root> <priority value ="debug" /> <appender-ref ref="ConsoleAppender"/> </root> </log4j:configuration> |
<appender name="ConsoleAppender" class="org.apache.log4j.ConsoleAppender"> <layout class="org.apache.log4j.SimpleLayout"/> </appender> |
<root> <priority value ="debug" /> <appender-ref ref="ConsoleAppender"/> </root> |
DOMConfigurator.configure("configurationfile.xml"); |
DOMConfigurator 用一棵DOM樹來初始化log4j環境。這裡是示例中的XML配置檔案:plainlog4jconfig.xml。這裡是執行該配置檔案的程式: files/externalxmltest.java:
import org.apache.log4j.Logger; import org.apache.log4j.xml.DOMConfigurator; public class externalxmltest { static Logger logger = Logger.getLogger(filetest.class); public static void main(String args[]) { DOMConfigurator.configure("xmllog4jconfig.xml"); logger.debug("Here is some DEBUG"); logger.info("Here is some INFO"); logger.warn("Here is some WARN"); logger.error("Here is some ERROR"); logger.fatal("Here is some FATAL"); } } |
這裡是一個實現帶有PatternLayout的FileAppender的日誌記錄器Logger的XML配置檔案:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="appender" class="org.apache.log4j.FileAppender"> <param name="File" value="Indentify-Log.txt"/> <param name="Append" value="false"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d [%t] %p - %m%n"/> </layout> </appender> <root> <priority value ="debug"/> <appender-ref ref="appender"/> </root> </log4j:configuration> |
你可以從這裡下載示例: xmllog4jconfig2.xml。 想要得到更多的使用XML檔案配置log4j環境的例子,請檢視log4j發行版的目錄src/java/org/apache/log4j/xml/examples/ 。
這就是上面討論的文字檔案形式的配置檔案:
# initialise root logger with level DEBUG and call it BLAHlog4j.rootLogger=DEBUG, BLAH# add a ConsoleAppender to the logger BLAHlog4j.appender.BLAH= org.apache.log4j.ConsoleAppender# set set that layout to be SimpleLayoutlog4j.appender.BLAH.layout= org.apache.log4j.SimpleLayout |
從這裡可以下載: plainlog4jconfig.txt。這就是執行該配置檔案的程式:
import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; public class externalplaintest { static Logger logger = Logger.getLogger(externalplaintest.class); public static void main(String args[]) { PropertyConfigurator.configure("plainlog4jconfig.xml"); logger.debug("Here is some DEBUG"); logger.info("Here is some INFO"); logger.warn("Here is some WARN"); logger.error("Here is some ERROR"); logger.fatal("Here is some FATAL"); } } |
你可以下載使用該配置檔案的示例: externalplaintest.java。想要獲得更多的使用文字檔案配置log4j環境的例子,請檢視log4j發行版中的目錄examples。
使用外部配置檔案的例子就簡單的討論到這裡,現在應該可以肯定你已經有能力獨立學習更多的log4j發行版和測試版中提供的例子。
文章轉自:http://www.blogjava.net/hellxoul/archive/2011/11/30/365181.html
相關文章
- Log4j詳細使用教程
- log4j介紹以及使用教程
- 最詳細的Log4j使用教程
- Log4J入門教程(一) 入門例程
- Java日誌服務入門系列教程——(2)Apache log4j入門JavaApache
- log4j 詳解
- log4j:WARN Please initialize the log4j system properly解決辦法
- Spring整合log4jSpring
- Spring配置log4jSpring
- log4j使用總結
- log4j入門(轉)
- log4j使用示例 (轉)
- log4j配置詳解
- exclude Log4j print Log
- Log4j漏洞原始碼分析原始碼
- 日誌log4j的配置
- log4j日誌級別
- Spring MVC整合 Log4jSpringMVC
- log4j配置檔案示例
- log4j的學習使用
- [JavaWeb]Log4j的前因後果JavaWeb
- springboot log4j的坑Spring Boot
- java log4j 的一個bugJava
- 比較全的log4j示例
- log4j日誌檔案配置
- log4j日誌配置詳解
- log4j配置檔案詳解
- 在eclipse中使用log4jEclipse
- 在Spring中配置log4jSpring
- 使用log4j將資料流入flume
- Log4j 日誌體系結構
- log4j日誌級別以及配置
- java中Log4J的使用筆記Java筆記
- 【web】log4j列印mybatis的日誌WebMyBatis
- 使用Log4j進行日誌操作
- tomcat log4j時區設定Tomcat
- java中log4j的使用體驗Java
- Log4J 2.16.0版本又爆新漏洞