天天看点

Log4J的XML格式配置方式例子

xmllog4jconfig.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>

对比properties方式和xml方式,可以看出他们程序中,除了定义读取配置文件的方式不同外,其它的根本就没

有区别了,这也就是log4j的魅力所在了,不需要改变程序,只需要通过改变定义的配置文件,我们就可以控制日志的输

出方式,是否输出,输出格式。我们可以通过定义不同的xml文件来控制输出方式.以下是各种输出方式与布局的例子。

4.2.3 比较简单的一个。

<?xml version="1.0" encoding="gb2312" ?>

<!--

   配置输出的日志目录为在控制台。

   格式采用为patternloyout,并且样式为:%d{iso8601} %r [%c :: %p %m]%n

--> 

<appender name="ca" class="org.apache.log4j.consoleappender">  

         <param name="conversionpattern" value="%d{iso8601} %r [%c :: %p %m]%n"/>

    <appender-ref ref="ca"/>

4.2.4 文件的输出 pattern的布局

          <param name="conversionpattern" value="%d [%t] %p - %m%n"/>

    <appender-ref ref="appender"/>

4.2.5 控制台的输出 和简单的布局

<appender name="consoleappender" class="org.apache.log4j.consoleappender">

       <layout class="org.apache.log4j.simplelayout"/>

    <priority value ="debug" />

       <appender-ref ref="consoleappender"/>

4.2.6 定义三种输出方式,按照不同的级别,选择不同的输出方式.debug,info,级别通过system.out来打印。

warn,fatal通过system.err来输出。error,fatal发送到邮箱。

<log4j:configuration>

    <appender name="stdout" class="org.apache.log4j.consoleappender">

        <param name="target" value="system.out" />

        <layout class="org.apache.log4j.patternlayout">

               <param name="conversionpattern" value="[%d{iso8601}] %-5p %c %m %n" />

          </layout>

        <filter class="org.apache.log4j.varia.levelrangefilter">

               <param name="levelmin" value="debug"/>

               <param name="levelmax" value="info"/>

        </filter>

    </appender>

    <appender name="stderr" class="org.apache.log4j.consoleappender">

        <param name="target" value="system.err" />

               <param name="levelmin" value="warn"/>

              <param name="levelmax" value="fatal"/>

    <!--                          -->

    <!-- declare the smtpappender -->

    <appender name="email" class="org.apache.log4j.net.smtpappender">

        <param name="buffersize" value="512" />

        <param name="smtphost" value="mail.suiyuanwu.com" />

        <param name="from" value="log4j@server5" />

        <param name="to" value="[email protected]" />

        <param name="subject" value="[smtpappender] application message" />

               <param name="conversionpattern" value="[%d{iso8601}]%n%n%-5p%n%n%c%n%n%m%n%n" />

        </layout>

               <param name="levelmin" value="error"/>

               <param name="levelmax" value="fatal"/>

    <!--                           -->

    <!-- setup log4js root logger -->

    <root>

          <level value="all" />

        <appender-ref ref="stdout"/>

        <appender-ref ref="stderr"/>

        <appender-ref ref="email" />

   </root>

五、参考资料

1.http://www.vipan.com/htdocs/log4jhelp.html

         dont use system.out.println! use log4j - vipan singla

2.http://jakarta.apache.org/log4j/docs/manual.html

short introduction to log4j - ceki gülcü - march 2002

3.http://www-128.ibm.com/developerworks/cn/java/jw-log4j/

log4j提供了对日志记录的控制

4.http://logging.apache.org/log4j/docs/documentation.html

log4j提供的文档。

转帖自:http://jakarta.apache.org/log4j/ xml