spring+log4j

 Log4j是Apache的一個開放源代碼項目,經過使用Log4j,咱們能夠控制日誌信息輸送的目的地是控制檯、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等;咱們也能夠控制每一條日誌的輸出格式;經過定義每一條日誌信息的級別,咱們可以更加細緻地控制日誌的生成過程。最使人感興趣的就是,這些能夠經過一個配置文件來靈活地進行配置,而不須要修改應用的代碼。web

     如此強大的優越性,實際上手並不難,尤爲在spring框架下,使用log4j更是容易,下面介紹一下spring下的log4j應用。
 
    固然先要下載相應的jar包(log4j.jar)
 
首先是web.xml的配置,在web.xml中加入以下配置
 
   <context-param>
      <param-name> log4jConfigLocation</param-name>
      <param-value>/WEB-INF/props/log4j.properties</param-value>
   </context-param>
   <context-param>
      <param-name> log4jRefreshInterval</param-name>
      <param-value>6000</param-value>
   </context-param>
 

    <listener>
      <listener-class>
        org.springframework.web.util.Log4jConfigListener
      </listener-class>
   </listener>spring

 

說明: 在上文的配置裏,在上文的配置裏,Log4jConfigListener會去WEB-INF/props/log4j.propeties 讀取配置文件;開一條watchdog線程每60秒掃描一下配置文件的變化(這樣在web服務啓動後再去修改配置文件也不用從新啓動web服務了);並把web目錄的路徑壓入一個叫webapp.root的系統變量(webapp.root將在log4j.properties文件中使用)。

接下來是log4j.properties配置文件了,把它放在WEB-INF/props下,具體配置以下:apache

#log4j.rootLogger = [ level ] , appenderName, appenderName, ...
log4j.rootLogger = INFO, console, R
#level=INFO,all can be output
#console is set to be a ConsoleAppender
log4j.appender.console = org.apache.log4j.ConsoleAppender
#console have four patterns
#org.apache.log4j.HTMLLayout
#org.apache.log4j.PatternLayout
#org.apache.log4j.SimpleLayout
#org.apache.log4j.TTCCLayout

log4j.appender.console.layout = org.apache.log4j.PatternLayout
#define the output type
log4j.appender.console.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
#file is set to output to a extra file
log4j.appender.R = org.apache.log4j.RollingFileAppender
#the absolute route of the log4j file
log4j.appender.R.File = /log.txt
#the size
log4j.appender.R.MaxFileSize = 500KB
#back up a file
log4j.appender.R.MaxBackupIndex = 1
log4j.appender.R.layout = org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] - %m%n服務器

上面的配置文件說明log信息將以兩種方式輸出(文件和控制檯),表示應用的根目錄下(例如本應用名稱爲ABC,則log.txt的位置爲tomact\webapp\ABC下)app

最後在程序中想要輸出log的地方加入log4j的支持框架

(1)引入   import org.apache.log4j.Loggerwebapp

(2)聲明一個logger佈局

private static Logger logger = Logger.getLogger(ClassName.class);spa

(3)在程序中的相應位置加入輸出信息開放源代碼

logger.info("用戶登陸:"+user.getAccount());

ok,完成了,當有登陸時會在控制檯和文件中同時輸出log信息以下

2007-01-10 16:02:54 [com.my.web.UserAction]-[INFO] 用戶登陸:yangsq

附註(轉):如下是配置文件(log4j.properties)的一些重要的語法定義配置文件其實您也能夠徹底不使用配置文件,而是在代碼中配置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.classlog4j.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.classlog4j.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(包含日誌產生的時間、線程、類別等等信息)

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息