log4j properties

1.2. Log4j簡介

在強調可重用組件開發的今天,除了自己從頭到尾開發一個可重用的日誌操作類外,Apache爲我們提供了一個強有力的日誌操作包-Log4j。
Log4j是Apache的一個開放源代碼項目,通過使用Log4j,我們可以控制日誌信息輸送的目的地是控制檯、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等;我們也可以控制每一條日誌的輸出格式;通過定義每一條日誌信息的級別,我們能夠更加細緻地控制日誌的生成過程。最令人感興趣的就是,這些可以通過一個配置文件來靈活地進行配置,而不需要修改應用的代碼。
此外,通過Log4j其他語言接口,您可以在C、C++、.Net、PL/SQL程序中使用Log4j,其語法和用法與在Java程序中一樣,使得多語言分佈式系統得到一個統一一致的日誌組件模塊。而且,通過使用各種第三方擴展,您可以很方便地將Log4j集成到J2EE、JINI甚至是SNMP應用中。本文介紹的Log4j版本是1.2.8,怎樣通過一個配置文件來靈活地進行配置,主要的應用平臺是Tomcat4.

1.3。Log4j的配置。

首先到jakarta下載一個log4j的組件。把jakarta-log4j-1.2.8/dist/lib下的log4j-1.2.8.jar文件copy到classpath指定的目錄下!可以是Tomcat的common/lib目錄下,也可以是你需要用到log4j的application下的lib目錄。
1.4在Application目錄下的web.xml文件加入以後代碼

log4j
com.apache.jakarta.log4j.Log4jInit

log4j
/WEB-INF/log4j.properties

1


這段代碼的意思是說,在Tomcat啓動時加載com.apache.jakarta.log4j.Log4jInit這個名叫Log4jInit.class這個類文件。其中Log4jInit.class的源代碼如下

package com.apache.jakarta.log4j;
import org.apache.log4j.PropertyConfigurator;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Log4jInit extends HttpServlet {

public void init() {
String prefix = getServletContext().getRealPath("/");
String file = getInitParameter("log4j");
// if the log4j-init-file is not set, then no point in trying
System.out.println("................log4j start");
if(file != null) {
PropertyConfigurator.configure(prefix+file);
}
}
public void doGet(HttpServletRequest req, HttpServletResponse res) {
}
}
這段代碼很簡單,可以看出,在加載的過程中,程序會讀取/WEB-INF/log4j.properties這個文件
這個文件就是本文的重點,也就是log4j的配置文件。

# Set root logger level to DEBUG and its only appender to A1
#log4j中有五級logger
#FATAL 0
#ERROR 3
#WARN 4
#INFO 6
#DEBUG 7
#配置根Logger,其語法爲:
#log4j.rootLogger = [ level ] , appenderName, appenderName, …
log4j.rootLogger=INFO, A1 ,R
#這一句設置以爲着所有的log都輸出
#如果爲log4j.rootLogger=WARN, 則意味着只有WARN,ERROR,FATAL
#被輸出,DEBUG,INFO將被屏蔽掉.
# A1 is set to be a ConsoleAppender.
#log4j中Appender有幾層如控制檯、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等
#ConsoleAppender輸出到控制檯
log4j.appender.A1=org.apache.log4j.ConsoleAppender
# A1 使用的輸出佈局,其中log4j提供4種佈局. org.apache.log4j.HTMLLayout(以HTML表格形式佈局)
#org.apache.log4j.PatternLayout(可以靈活地指定佈局模式),
#org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),
#org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)

log4j.appender.A1.layout=org.apache.log4j.PatternLayout
#靈活定義輸出格式 具體查看log4j javadoc org.apache.log4j.PatternLayout
#d 時間 ....
log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
#R 輸出到文件 RollingFileAppender的擴展,可以提供一種日誌的備份功能。
log4j.appender.R=org.apache.log4j.RollingFileAppender
#日誌文件的名稱
log4j.appender.R.File=log4j.log
#日誌文件的大小
log4j.appender.R.MaxFileSize=100KB
# 保存一個備份文件
log4j.appender.R.MaxBackupIndex=1

log4j.appender.R.layout=org.apache.log4j.TTCCLayout
#log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n

配置以這裏就差不多了,如果你想更深入瞭解配置文件的各個細節,可以去查看docs。還有,在文章的最後面我們提供配置文件中一些主要的語法。下面我們來看看怎樣在程序中使用log4j.

1.4 Log4j的使用。
使用Log4j,第一步就是獲取日誌記錄器,這個記錄器將負責控制日誌信息。其語法爲:
public static Logger getLogger( String name),
必須在使用前要把這個類導入
import org.apache.log4j.Logger;

name一般是類文件的名字,如下:
static Logger logger = Logger.getLogger ("".class.getName () ) ;

您就可以輕鬆地使用不同優先級別的日誌記錄語句插入到您想記錄日誌的任何地方,其語法如下:
logger.debug ( Object message ) ;
logger.info ( Object message ) ;
logger.warn ( Object message ) ;
logger.error ( Object message ) ;

爲什麼這裏要分級別的呢?試想一下,我們在寫程序的時候,爲了調試程序,會在很多會出錯的地方加入大量的logger.info();信息。當然程序調試完畢,我們不需要這些輸出信息了,那怎麼辦呢?以前的做法是把每個程序中的logger.info刪除,但這是不現實的,如果程序不大還可以,但如果程序很多,做這些事情就很煩人了。但因爲log4j分級別了,當我們不需要輸出這樣調試時用到的log.info()時,我們可以把輸出的級別調高,如調到warn,或error級別,這樣info級別及以下的級別就不會出輸出了,是不是很方便的呢?

其實除了這種使用方式,log4j還有其它的使用方面,不需要配置文件,直接在程序中定義輸入出級別,層次等信息,如果要了解這方法的使用,可以參考文檔。

1.5。附註:
以下是配置文件的一些重要的語法
定義配置文件

其實您也可以完全不使用配置文件,而是在代碼中配置Log4j環境。但是,使用配置文件將使您的應用程序更加靈活。

Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是Java特性文件(鍵=值)。下面我們介紹使用Java特性文件做爲配置文件的方法:

配置根Logger,其語法爲:

log4j.rootLogger = [ level ] , appenderName, appenderName, …
其中,level 是日誌記錄的優先級,分爲OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這裏定義的級別,您可以控制到應用程序中相應級別的日誌信息的開關。比如在這裏定義了INFO級別,則應用程序中所有DEBUG級別的日誌信息將不被打印出來。
appenderName就是指定日誌信息輸出到哪個地方。您可以同時指定多個輸出目的地。

配置日誌信息輸出目的地Appender,其語法爲

log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1

log4j.appender.appenderName.option = valueN
其中,Log4j提供的appender有以下幾種:
org.apache.log4j.ConsoleAppender(控制檯),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天產生一個日誌文件),org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)

配置日誌信息的格式(佈局),其語法爲:

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1

log4j.appender.appenderName.layout.option = valueN
其中,Log4j提供的layout有以下幾種:
org.apache.log4j.HTMLLayout(以HTML表格形式佈局),
org.apache.log4j.PatternLayout(可以靈活地指定佈局模式),
org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),
org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/squall098/archive/2006/08/06/1027737.aspx

發佈了34 篇原創文章 · 獲贊 47 · 訪問量 20萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章