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/"&gt
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"  ?>
<! DOCTYPE log4j:configuration SYSTEM "log4j.dtd" >
< log4j:configuration  xmlns:log4j ="http://jakarta.apache.org/log4j/" >
<!--
   配置输出的日志目录为在控制台。
   格式采用为PatternLoyout,并且样式为:%d{ISO8601} %r [%c :: %p %m]%n
-->  
< appender  name ="CA"  class ="org.apache.log4j.ConsoleAppender" >   
       
< layout  class ="org.apache.log4j.PatternLayout" >
         
< param  name ="ConversionPattern"  value ="%d{ISO8601} %r [%c :: %p %m]%n" />
       
</ layout >
</ appender >

< root >
       
< priority  value  ="debug" />
    
< appender-ref  ref ="CA" />
</ root >

</ log4j:configuration >


4.2.4 文件的输出 pattern的布局
<? 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 >


4.2.5 控制台的输出 和简单的布局
<? xml version="1.0" encoding="UTF-8"  ?>
<! DOCTYPE log4j:configuration SYSTEM "log4j.dtd" >

< log4j:configuration  xmlns:log4j ="http://jakarta.apache.org/log4j/" >
      
< appender  name ="ConsoleAppender"  class ="org.apache.log4j.ConsoleAppender" >
       
< layout  class ="org.apache.log4j.SimpleLayout" />
</ appender >

< root >
    
< priority  value  ="debug"   />
       
< appender-ref  ref ="ConsoleAppender" />
</ root >

</ log4j:configuration >


4.2.6 定义三种输出方式,按照不同的级别,选择不同的输出方式.debug,info,级别通过System.out来打印。
WARN,FATAL通过System.err来输出。ERROR,FATAL发送到邮箱。

<? xml version="1.0" encoding="UTF-8"  ?>
<! DOCTYPE log4j:configuration SYSTEM "log4j.dtd" >
< 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"   />
        
< 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 ="WARN" />
              
< param  name ="LevelMax"  value ="FATAL" />
        
</ filter >
    
</ appender >

    
<!--                            -->
    
<!--  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 ="web@suiyuanwu.com"   />
        
< param  name ="Subject"  value ="[SMTPAppender] Application message"   />
        
< layout  class ="org.apache.log4j.PatternLayout" >
               
< param  name ="ConversionPattern"  value ="[%d{ISO8601}]%n%n%-5p%n%n%c%n%n%m%n%n"   />
        
</ layout >
        
< filter  class ="org.apache.log4j.varia.LevelRangeFilter" >
               
< param  name ="LevelMin"  value ="ERROR" />
               
< param  name ="LevelMax"  value ="FATAL" />
        
</ filter >
    
</ appender >

    
<!--                             -->
    
<!--  setup log4js root logger  -->
    
<!--                             -->
    
< root >
          
< level  value ="all"   />
        
< appender-ref  ref ="STDOUT" />
        
< appender-ref  ref ="STDERR" />
        
< appender-ref  ref ="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
相关文章
|
20天前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
156 30
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
2月前
|
XML Java 应用服务中间件
springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
通过一个HelloWorld实例,介绍了SpringMVC的基本概念、执行流程,并详细讲解了如何创建和配置第一个SpringMVC项目(基于XML)。
springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
|
1月前
|
XML 分布式计算 资源调度
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(一)
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(一)
156 5
|
1月前
|
XML 资源调度 网络协议
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(二)
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(二)
103 4
|
1月前
|
分布式计算 资源调度 Hadoop
大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
79 4
|
1月前
|
网络协议 Linux Windows
Rsyslog配置不同端口收集不同设备日志
Rsyslog配置不同端口收集不同设备日志
|
1月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
39 1
|
1月前
|
数据采集 监控 Java
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
本文是关于SpringBoot日志的详细教程,涵盖日志的定义、用途、SLF4J框架的使用、日志级别、持久化、文件分割及格式配置等内容。
158 0
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
|
1月前
|
XML Java 数据格式
手动开发-简单的Spring基于XML配置的程序--源码解析
手动开发-简单的Spring基于XML配置的程序--源码解析
82 0
|
1月前
|
XML JSON 前端开发
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
388 0
下一篇
无影云桌面