Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的

 

vampire_315 原创   更新:2006-12-18 17:35:39  版本: 1.0   

 

 

Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的,它可接key=value格式的设置或xml格式的设置信息。通过配置,可以创建出Log4J的运行环境。

1. 配置文件
Log4J配置文件的基本格式如下:

 #配置根Logger
log4j.rootLogger  =   [ level ]   ,  appenderName1 ,  appenderName2 ,  …

#配置日志信息输出目的地Appender
log4j.appender.appenderName  =  fully.qualified.name.of.appender.class
  log4j.appender.appenderName.option1  =  value1
  …
  log4j.appender.appenderName.optionN  =  valueN

#配置日志信息的格式(布局)
log4j.appender.appenderName.layout  =  fully.qualified.name.of.layout.class
  log4j.appender.appenderName.layout.option1  =  value1
  …
  log4j.appender.appenderName.layout.optionN  =  valueN  
其中 [level] 是日志输出级别,共有5级:
FATAL      0  
ERROR      3  
WARN       4  
INFO       6  
DEBUG      7
 
Appender 为日志输出目的地,Log4j提供的appender有以下几种:
 org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
Layout:日志输出格式,Log4j提供的layout有以下几种:
 org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
打印参数: Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,如下:
   %m   输出代码中指定的消息
  %p   输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
  %r   输出自应用启动到输出该log信息耗费的毫秒数
  %c   输出所属的类目,通常就是所在类的全名
  %t   输出产生该日志事件的线程名
  %n   输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
  %d   输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日  22 : 10 : 28 , 921  
  %l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java: 10 )  
2. 在代码中初始化Logger:
1)在程序中调用BasicConfigurator.configure()方法:给根记录器增加一个ConsoleAppender,输出格式通过 PatternLayout设为"%-4r [%t] %-5p %c %x - %m%n",还有根记录器的默认级别是Level.DEBUG.
2)配置放在文件里,通过命令行参数传递文件名字,通过PropertyConfigurator.configure(args[x])解析并配置;
3)配置放在文件里,通过环境变量传递文件名等信息,利用log4j默认的初始化过程解析并配置;
4)配置放在文件里,通过应用服务器配置传递文件名等信息,利用一个特殊的servlet来完成配置。

3. 为不同的 Appender 设置日志输出级别:
当调试系统时,我们往往注意的只是异常级别的日志输出,但是通常所有级别的输出都是放在一个文件里的,如果日志输出的级别是BUG!?那就慢慢去找吧。
这时我们也许会想要是能把异常信息单独输出到一个文件里该多好啊。当然可以,Log4j已经提供了这样的功能,我们只需要在配置中修改Appender的Threshold 就能实现,比如下面的例子:

[配置文件]
 ### set log levels ###
log4j.rootLogger = debug ,  stdout ,  D ,  E

### 输出到控制台 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n

### 输出到日志文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG ## 输出DEBUG级别以上的日志
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 保存异常信息到单独文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/error.log ## 异常日志文件名
log4j.appender.D.Append = true
log4j.appender.D.Threshold = ERROR ## 只输出ERROR级别以上的日志!!!
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
[代码中使用]
  public   class  TestLog4j   {
     public   static   void  main(String[] args)   {
        PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " );
        Logger logger  =  Logger.getLogger(TestLog4j. class );
        logger.debug( " debug " );
        logger.error( " error " );
    }
}
运行一下,看看异常信息是不是保存在了一个单独的文件error.log中.

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是一个简单的log4j的XML配置文件例子: ```xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/doc-files/log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender"> <param name="Target" value="System.out"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n"/> </layout> </appender> <appender name="FILE" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logs/mylog.log"/> <param name="Append" value="true"/> <param name="MaxFileSize" value="10MB"/> <param name="MaxBackupIndex" value="10"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n"/> </layout> </appender> <logger name="com.mycompany"> <level value="INFO"/> <appender-ref ref="FILE"/> </logger> <root> <level value="ERROR"/> <appender-ref ref="CONSOLE"/> </root> </log4j:configuration> ``` 在这个例子中,我们定义了两个appender:CONSOLE和FILE。CONSOLE是一个ConsoleAppender,将日志输出到控制台上;FILE是一个RollingFileAppender,将日志输出到logs/mylog.log文件中。我们还定义了两个logger:com.mycompany和root。com.mycompany的日志级别设置为INFO,将日志输出到FILE中;root的日志级别设置为ERROR,将日志输出到CONSOLE中。 这个配置文件使用了log4j.dtd,用于指定DTD及其命名空间。DTD是一种XML文档类型定义,它定义了XML文档中允许出现的元素、属性和实体,以及它们之间的关系。 ### 回答2: log4j的XML配置文件是用于配置log4j日志框架的关键文件之一。通过该文件,我们可以定义日志的输出格式、输出级别、输出目标等。 XML配置文件中的关键元素包括: 1. `<log4j:configuration>`:配置文件的根元素,表示一个log4j的配置文件。 2. `<appender>`:定义将日志信息发送到哪个目标,比如文件、控制台等。可以配置多个appender。 3. `<layout>`:定义日志的输出格式,如时间、日志级别、类名、消息等。常用的layout有`PatternLayout`和`SimpleLayout`。 4. `<root>`:定义根Logger的输出级别和appender。根Logger是所有Logger的父Logger,可以定义全局的输出级别和appender。 5. `<logger>`:定义特定包或类的Logger的输出级别和appender。 在XML配置文件中,我们可以通过配置不同元素的属性来实现对日志的灵活配置。比如可以通过设置`threshold`属性来指定输出级别,通过设置`file`属性来指定日志输出到文件等。 一个简单的log4j的XML配置文件示例如下: ```xml <?xml version="1.0" encoding="UTF-8"?> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender"> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" /> </layout> </appender> <root> <priority value="DEBUG" /> <appender-ref ref="CONSOLE" /> </root> </log4j:configuration> ``` 以上配置定义了一个名为`CONSOLE`的appender,将日志输出到控制台,并使用`PatternLayout`作为输出格式。根Logger的输出级别为DEBUG,并将日志输出到`CONSOLE` appender中。 通过灵活配置log4j的XML配置文件,我们可以根据实际需求定义日志的格式和输出目标,从而更好地进行日志管理和排查问题。 ### 回答3: log4j是一个开源的Java日志管理工具,用于记录应用程序的日志信息。XML配置文件log4j的一种配置方式,用于指定日志输出的格式、位置和级别等信息。 XML配置文件的结构主要包括根元素<log4j:configuration>和子元素<appender>、<logger>等。 <log4j:configuration>元素是XML配置文件的根元素,包含了整个配置的信息。它可以包含多个<appender>和<logger>。 <appender>元素用于定义日志记录的输出目标。它可以定义不同的输出方式,如控制台输出、文件输出等。每个<appender>元素都有一个唯一的名称,并可以通过<appender-ref>元素来引用。 <logger>元素用于定义应用程序的日志记录器。每个<logger>元素都有一个唯一的名称和一个级别。可以使用<appender-ref>元素将<logger>元素与<appender>元素关联起来,以将日志信息写入指定的输出目标。 XML配置文件还可以定义日志级别、日志格式等信息。日志级别包括DEBUG、INFO、WARN、ERROR和FATAL等,可以根据不同的需求进行设置。日志格式可以使用PatternLayout指定,包括日期、日志级别、类名、线程名等信息。 通过修改XML配置文件,可以方便地调整日志的输出方式和级别,使程序的日志信息更易读、更易管理。同时,XML配置文件的结构清晰,易于理解和维护。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值