xmllog4jconfig.xml 如下:
对比properties方式和xml方式,可以看出他们程序中,除了定义读取配置文件的方式不同外,其它的根本就没
有区别了,这也就是log4j的魅力所在了,不需要改变程序,只需要通过改变定义的配置文件,我们就可以控制日志的输
出方式,是否输出,输出格式。我们可以通过定义不同的xml文件来控制输出方式.以下是各种输出方式与布局的例子。
4.2.3 比较简单的一个。
4.2.4 文件的输出 pattern的布局
4.2.5 控制台的输出 和简单的布局
4.2.6 定义三种输出方式,按照不同的级别,选择不同的输出方式.debug,info,级别通过System.out来打印。
WARN,FATAL通过System.err来输出。ERROR,FATAL发送到邮箱。
五、参考资料
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
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="appender"class="org.apache.log4j.FileAppender">
<paramname="File"value="Indentify-Log.txt"/>
<paramname="Append"value="false"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d[%t]%p-%m%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="appender"/>
</root>
</log4j:configuration>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="appender"class="org.apache.log4j.FileAppender">
<paramname="File"value="Indentify-Log.txt"/>
<paramname="Append"value="false"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d[%t]%p-%m%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="appender"/>
</root>
</log4j:configuration>
对比properties方式和xml方式,可以看出他们程序中,除了定义读取配置文件的方式不同外,其它的根本就没
有区别了,这也就是log4j的魅力所在了,不需要改变程序,只需要通过改变定义的配置文件,我们就可以控制日志的输
出方式,是否输出,输出格式。我们可以通过定义不同的xml文件来控制输出方式.以下是各种输出方式与布局的例子。
4.2.3 比较简单的一个。
<?xmlversion="1.0"encoding="gb2312"?>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<!--
配置输出的日志目录为在控制台。
格式采用为PatternLoyout,并且样式为:%d{ISO8601}%r[%c::%p%m]%n
-->
<appendername="CA"class="org.apache.log4j.ConsoleAppender">
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d{ISO8601}%r[%c::%p%m]%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="CA"/>
</root>
</log4j:configuration>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<!--
配置输出的日志目录为在控制台。
格式采用为PatternLoyout,并且样式为:%d{ISO8601}%r[%c::%p%m]%n
-->
<appendername="CA"class="org.apache.log4j.ConsoleAppender">
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d{ISO8601}%r[%c::%p%m]%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="CA"/>
</root>
</log4j:configuration>
4.2.4 文件的输出 pattern的布局
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="appender"class="org.apache.log4j.FileAppender">
<paramname="File"value="Indentify-Log.txt"/>
<paramname="Append"value="false"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d[%t]%p-%m%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="appender"/>
</root>
</log4j:configuration>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="appender"class="org.apache.log4j.FileAppender">
<paramname="File"value="Indentify-Log.txt"/>
<paramname="Append"value="false"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="%d[%t]%p-%m%n"/>
</layout>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="appender"/>
</root>
</log4j:configuration>
4.2.5 控制台的输出 和简单的布局
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="ConsoleAppender"class="org.apache.log4j.ConsoleAppender">
<layoutclass="org.apache.log4j.SimpleLayout"/>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="ConsoleAppender"/>
</root>
</log4j:configuration>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configurationxmlns:log4j="http://jakarta.apache.org/log4j/">
<appendername="ConsoleAppender"class="org.apache.log4j.ConsoleAppender">
<layoutclass="org.apache.log4j.SimpleLayout"/>
</appender>
<root>
<priorityvalue="debug"/>
<appender-refref="ConsoleAppender"/>
</root>
</log4j:configuration>
4.2.6 定义三种输出方式,按照不同的级别,选择不同的输出方式.debug,info,级别通过System.out来打印。
WARN,FATAL通过System.err来输出。ERROR,FATAL发送到邮箱。
<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configuration>
<appendername="STDOUT"class="org.apache.log4j.ConsoleAppender">
<paramname="Target"value="System.out"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%-5p%c%m%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="DEBUG"/>
<paramname="LevelMax"value="INFO"/>
</filter>
</appender>
<appendername="STDERR"class="org.apache.log4j.ConsoleAppender">
<paramname="Target"value="System.err"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%-5p%c%m%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="WARN"/>
<paramname="LevelMax"value="FATAL"/>
</filter>
</appender>
<!---->
<!--DeclaretheSMTPAppender-->
<!---->
<appendername="EMAIL"class="org.apache.log4j.net.SMTPAppender">
<paramname="BufferSize"value="512"/>
<paramname="SMTPHost"value="mail.suiyuanwu.com"/>
<paramname="From"value="log4j@server5"/>
<paramname="To"value="web@suiyuanwu.com"/>
<paramname="Subject"value="[SMTPAppender]Applicationmessage"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%n%n%-5p%n%n%c%n%n%m%n%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="ERROR"/>
<paramname="LevelMax"value="FATAL"/>
</filter>
</appender>
<!---->
<!--setuplog4jsrootlogger-->
<!---->
<root>
<levelvalue="all"/>
<appender-refref="STDOUT"/>
<appender-refref="STDERR"/>
<appender-refref="EMAIL"/>
</root>
</log4j:configuration>
<!DOCTYPElog4j:configurationSYSTEM"log4j.dtd">
<log4j:configuration>
<appendername="STDOUT"class="org.apache.log4j.ConsoleAppender">
<paramname="Target"value="System.out"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%-5p%c%m%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="DEBUG"/>
<paramname="LevelMax"value="INFO"/>
</filter>
</appender>
<appendername="STDERR"class="org.apache.log4j.ConsoleAppender">
<paramname="Target"value="System.err"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%-5p%c%m%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="WARN"/>
<paramname="LevelMax"value="FATAL"/>
</filter>
</appender>
<!---->
<!--DeclaretheSMTPAppender-->
<!---->
<appendername="EMAIL"class="org.apache.log4j.net.SMTPAppender">
<paramname="BufferSize"value="512"/>
<paramname="SMTPHost"value="mail.suiyuanwu.com"/>
<paramname="From"value="log4j@server5"/>
<paramname="To"value="web@suiyuanwu.com"/>
<paramname="Subject"value="[SMTPAppender]Applicationmessage"/>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern"value="[%d{ISO8601}]%n%n%-5p%n%n%c%n%n%m%n%n"/>
</layout>
<filterclass="org.apache.log4j.varia.LevelRangeFilter">
<paramname="LevelMin"value="ERROR"/>
<paramname="LevelMax"value="FATAL"/>
</filter>
</appender>
<!---->
<!--setuplog4jsrootlogger-->
<!---->
<root>
<levelvalue="all"/>
<appender-refref="STDOUT"/>
<appender-refref="STDERR"/>
<appender-refref="EMAIL"/>
</root>
</log4j:configuration>
五、参考资料
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
本文详细介绍了使用XML配置Log4j的方法,包括控制台输出、文件输出及多种布局方式,并展示了如何根据不同日志级别选择输出途径。
1278

被折叠的 条评论
为什么被折叠?



