隨筆 - 40, 文章 - 0, 評(píng)論 - 20, 引用 - 0
          數(shù)據(jù)加載中……

          精通Log4j

          ?log4j雖然總的來說是比較容易使用的,但是要是想比較精通的操縱它還是有很多地方值得探討的。
          ??? 這幾天有空,把項(xiàng)目中大家用到的log4j實(shí)現(xiàn)的功能分了一下類,大致分為下面三類:
          ??? <1>所有的日志信息都輸出到log.log.
          ??? <2>對(duì)于一些特殊的日志(如啟動(dòng)時(shí)候的日志),輸出到log/startup/startup.log.
          ??? <3>對(duì)于某些特殊包下面的日志,如com.aspire包下面的error信息都輸出到error.log???
          ??? 有了這幾個(gè)功能,相信對(duì)于大部分的系統(tǒng)都是夠用的了,下面這個(gè)例子就是實(shí)現(xiàn)了這幾個(gè)功能:
          ??? (至于其他的一些配置,如格式這些的就不說明,有很多這種資料)
          ???
          ??? ***********? log4j 配置文件? ************???
          ???
          <?xml version="1.0" encoding="UTF-8"?>
          <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
          <log4j:configuration xmlns:log4j="

          <appender name="file" class="org.apache.log4j.RollingFileAppender">
          ?<param name="File" value="log.log"/>
          ?<layout class="org.apache.log4j.PatternLayout">
          ?<param name="ConversionPattern" value=" %d{ISO8601} [%c]- %m%n"/>
          ?</layout>
          </appender>

          <appender name="error" class="org.apache.log4j.RollingFileAppender">
          ??<param name="File" value="error.log"/>
          ??<param name="MaxBackupIndex" value="300"/>
          ??<param name="Encoding" value="GB2312"/>
          ??<param name="MaxFileSize" value="20MB"/>
          ??<layout class="org.apache.log4j.PatternLayout">
          ???<param name="ConversionPattern" value="%d{ISO8601} %p [%c] - [%m]%n"/>
          ??</layout>
          ??? <filter class="org.apache.log4j.varia.LevelRangeFilter">
          ??<!-- 過濾,只記錄error信息-->
          ??<param name="LevelMin" value="error"/>
          ??<param name="LevelMax" value="error"/>
          ??<param name="acceptOnMatch" value="true"/>
          ??? </filter>
          </appender>
          <appender name="startup" class="com.aspire.TimeSizeRollingFileAppender">
          ??<!--該類使自己從FileAppender派生,可以自己控制輸出文件的路徑 -->
          ??<param name="File" value="log/startup/startup.log" />
          ??<param name="Encoding" value="GBK" />
          ??<layout class="org.apache.log4j.PatternLayout">
          ???<param name="ConversionPattern" value="%m %d{ISO8601}- %m%n %p %l%n" />
          ??</layout>
          </appender>

          <logger name="biz.startup">
          <!--Logger logger = Logger.getLogger("biz.startup") 可以這樣來調(diào)用本logger-->
          ??<level value="debug" />
          ??<appender-ref ref="startup" />
          </logger>

          <logger name="com.aspire" additivity="false">
          <!--Log log = LogFactory.getLog(TestLog4j.class) 此時(shí)如果TestLog4j
          ??? 位于com.aspire包下面,那么使用本logger
          ?-->
          ??<level value="debug"/>
          ??<appender-ref ref="error"/>
          </logger>
          <root>
          <level value="info"/>
          <!-- 默認(rèn)輸出到log.log-->
          <appender-ref ref="file"/>
          </root>
          </log4j:configuration>

          ***********? log4j 配置文件結(jié)束 ************

          **********? 派生的TimeSizeRollingFileAppender類*****
          package com.aspire;

          import org.apache.log4j.FileAppender;
          import org.apache.log4j.spi.ErrorCode;
          import java.io.File;
          import java.io.IOException;

          public class TimeSizeRollingFileAppender
          ??? extends FileAppender
          ??? implements ErrorCode {

          ? private final static String FS = System.getProperty("file.separator");
          ? public TimeSizeRollingFileAppender() {
          ? }
          ? public void setFile(String file) {
          ??? String val = file.trim();
          ??? File domain = new File(".");
          ??? try {
          ????? fileName = domain.getCanonicalPath() + FS + val;
          ??? }
          ??? catch (IOException ex) {
          ????? ex.printStackTrace();
          ??? }
          ? }
          }

          ********** TimeSizeRollingFileAppender 類結(jié)束 ******

          ************ 調(diào)用示例 TestLog4j類 **************
          package com.aspire;

          import org.apache.log4j.Logger;
          import org.apache.log4j.LogManager;
          import org.apache.commons.logging.LogFactory;
          import org.apache.log4j.xml.DOMConfigurator;
          import org.apache.commons.logging.Log;

          public class TestLog4j {
          ? private Logger logger = Logger.getLogger("biz.startup");
          ? private Log log = LogFactory.getLog(TestLog4j.class);

          ? public static void config(){
          ??? DOMConfigurator.configure("conf\\log4jConf.xml");
          ? }
          ? public void Test(){
          ??? /**
          ???? * error > warn > info > debug
          ???? */
          ??? logger.error("*****error*****");
          ??? logger.debug("****debug*****");
          ??? logger.warn("*****warn******");
          ??? logger.info("*****info******");
          ??? log.error("中華之崛起!");
          ? }
          ? public static void main(String [] argv){
          ??? TestLog4j t = new TestLog4j();
          ??? TestLog4j.config();
          ??? t.Test();
          ? }
          }

          ***************? TestLog4j end ***********

          posted on 2006-04-26 12:59 月亮 閱讀(407) 評(píng)論(0)  編輯  收藏


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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 神农架林区| 蓬溪县| 青冈县| 松原市| 中卫市| 宜兰市| 罗田县| 桐庐县| 济源市| 潼南县| 陇南市| 南平市| 遂昌县| 海阳市| 集安市| 温州市| 海宁市| 德兴市| 盐亭县| 霍邱县| 石台县| 古交市| 花莲县| 普宁市| 邹城市| 云和县| 新乐市| 保康县| 霸州市| 江津市| 肃北| 驻马店市| 双江| 黑河市| 白河县| 买车| 泰顺县| 洪湖市| 紫阳县| 西丰县| 十堰市|