Java蜘蛛人 歡迎大家

          歡迎大家 來(lái)到我的blog , 如果我身邊的朋友 有什么不懂可以直接來(lái)問(wèn)我 我會(huì)細(xì)心的幫助你的. 如果網(wǎng)絡(luò)上的朋友有什么不懂的 可以加我Java蜘蛛人 QQ48187537
          posts - 54, comments - 192, trackbacks - 0, articles - 1

          Spring 配置log4j

          Posted on 2009-02-12 15:16 Java蜘蛛人 --鄭成橋 閱讀(21004) 評(píng)論(0)  編輯  收藏

            Log4j是Apache的一個(gè)開(kāi)放源代碼項(xiàng)目,通過(guò)使用Log4j,我們可以控制日志信息輸送的目的地是控制臺(tái)、文件、GUI組件、甚至是套接口服務(wù)器、NT的事件記錄器、UNIX Syslog守護(hù)進(jìn)程等;我們也可以控制每一條日志的輸出格式;通過(guò)定義每一條日志信息的級(jí)別,我們能夠更加細(xì)致地控制日志的生成過(guò)程。最令人感興趣的就是,這些可以通過(guò)一個(gè)配置文件來(lái)靈活地進(jìn)行配置,而不需要修改應(yīng)用的代碼。

               如此強(qiáng)大的優(yōu)越性,實(shí)際上手并不難,尤其在spring框架下,使用log4j更是容易,下面介紹一下spring下的log4j應(yīng)用。
              當(dāng)然先要下載相應(yīng)的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>

          說(shuō)明:在上文的配置里,在上文的配置里,Log4jConfigListener會(huì)去WEB-INF/props/log4j.propeties 讀取配置文件;開(kāi)一條watchdog線程每60秒掃描一下配置文件的變化(這樣在web服務(wù)啟動(dòng)后再去修改配置文件也不用重新啟動(dòng)web服務(wù)了);并把web目錄的路徑壓入一個(gè)叫webapp.root的系統(tǒng)變量(webapp.root將在log4j.properties文件中使用)。

          接下來(lái)是log4j.properties配置文件了,把它放在WEB-INF/props下,具體配置如下:

          #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

          上面的配置文件說(shuō)明log信息將以兩種方式輸出(文件和控制臺(tái)),表示應(yīng)用的根目錄下(例如本應(yīng)用名稱為ABC,則log.txt的位置為tomact\webapp\ABC下)

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

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

          (2)聲明一個(gè)logger

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

          (3)在程序中的相應(yīng)位置加入輸出信息

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

          ok,完成了,當(dāng)有登錄時(shí)會(huì)在控制臺(tái)和文件中同時(shí)輸出log信息如下

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

          附注(轉(zhuǎn)):
          以下是配置文件(log4j.properties)的一些重要的語(yǔ)法
          定義配置文件

          其實(shí)您也可以完全不使用配置文件,而是在代碼中配置Log4j環(huán)境。但是,使用配置文件將使您的應(yīng)用程序更加靈活。

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

          配置根Logger,其語(yǔ)法為:

          log4j.rootLogger = [ level ] , appenderName, appenderName, …
          其中,level 是日志記錄的優(yōu)先級(jí),分為OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級(jí)別。Log4j建議只使用四個(gè)級(jí)別,優(yōu)先級(jí)從高到低分別是ERROR、WARN、INFO、DEBUG。通過(guò)在這里定義的級(jí)別,您可以控制到應(yīng)用程序中相應(yīng)級(jí)別的日志信息的開(kāi)關(guān)。比如在這里定義了INFO級(jí)別,則應(yīng)用程序中所有DEBUG級(jí)別的日志信息將不被打印出來(lái)。
          appenderName就是指定日志信息輸出到哪個(gè)地方。您可以同時(shí)指定多個(gè)輸出目的地。

          配置日志信息輸出目的地Appender,其語(yǔ)法為

          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(控制臺(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ā)送到任意指定的地方)

          配置日志信息的格式(布局),其語(yǔ)法為:

          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(包含日志信息的級(jí)別和信息字符串),
          org.apache.log4j.TTCCLayout(包含日志產(chǎn)生的時(shí)間、線程、類別等等信息)


          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 和田市| 阳江市| 平罗县| 平谷区| 金乡县| 仁怀市| 白银市| 合阳县| 改则县| 唐河县| 那坡县| 永吉县| 鄯善县| 南昌县| 江城| 凌云县| 沁水县| 大理市| 逊克县| 延津县| 昂仁县| 濮阳县| 叙永县| 武安市| 宝山区| 诏安县| 宜昌市| 册亨县| 类乌齐县| 湘西| 刚察县| 麦盖提县| 特克斯县| 厦门市| 安达市| 屏东县| 班戈县| 福清市| 岳普湖县| 恩平市| 鄂温|