Posted on 2007-08-07 18:21
itVincent 阅读(1707)
评论(0) 编辑 收藏 所属分类:
Java基础
1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE log4j:configuration PUBLIC "-//Apache//DTD Log4j 1.2//EN"
3 "http://logging.apache.org/log4j/docs/api/org/apache/log4j/xml/log4j.dtd">
4<log4j:configuration debug="false">
5
6 <appender name="FILE" class="org.apache.log4j.FileAppender">
7 <param name="File" value="../log/system.log" />
8 <param name="Append" value="false" />
9 <param name="Threshold" value="info" />
10 <layout class="org.apache.log4j.PatternLayout">
11 <param name="ConversionPattern" value="%d %-5p [%c{1}] %m%n" />
12 </layout>
13 </appender>
14
15 <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
16 <param name="Target" value="System.out"/>
17 <param name="Threshold" value="info" />
18 <layout class="org.apache.log4j.PatternLayout">
19 <param name="ConversionPattern"
20 value="%d{ABSOLUTE} %-5p [%c{1}] %m%n" />
21 </layout>
22 </appender>
23
24 <appender name="DAILYFILE" class="org.apache.log4j.DailyRollingFileAppender">
25 <param name="File" value="../log/daily_system.log" />
26 <param name="Append" value="true" />
27 <param name="Threshold" value="info" />
28 <param name="DatePattern" value="'.'yyyy-MM-dd" />
29 <layout class="org.apache.log4j.PatternLayout">
30 <param name="ConversionPattern" value="%d %-5p [%c{1}] %m%n" />
31 </layout>
32 </appender>
33
34 <appender name="DEBUG_FILE" class="org.apache.log4j.FileAppender">
35 <param name="File" value="../log/debug.log" />
36 <param name="Append" value="false" />
37 <!--<param name="Threshold" value="info" />-->
38 <layout class="org.apache.log4j.PatternLayout">
39 <param name="ConversionPattern" value="%d %-5p [%c] %m%n" />
40 </layout>
41 </appender>
42
43 <appender name="DEBUG_HTML" class="org.apache.log4j.FileAppender">
44 <param name="File" value="../log/debug.html" />
45 <param name="Append" value="false" />
46 <param name="Threshold" value="info" />
47 <layout class="org.apache.log4j.HTMLLayout">
48 <param name="Title" value="debug html log" />
49 </layout>
50 </appender>
51
52 <logger name="net.blogjava.itvinent">
53 <level value="debug"/>
54 <appender-ref ref="DEBUG_FILE"/>
55
56 </logger>
57
58
59 <root>
81 <level value="info"/>
82 <appender-ref ref="CONSOLE" />
83 <appender-ref ref="FILE" />
84 <appender-ref ref="DEBUG_HTML"/>
85 <appender-ref ref="DAILYFILE"/>
86 </root>
91</log4j:configuration>
本文适合对log4j有一定了解的朋友^_^
CONSOLE是控制台日志,在控制台上显示日志信息
FILE是文件日志,程序每次启动本文件会清空,写入新的日志
DEBUG_HTML是HTML日志,日志以HTML格式生成,方便用浏览器察看日志
DEBUG_FILE 是保存debug信息的日志文件
DAILYFILE是定时备份日志,程序启动时,会生成一个../log/daily_system.log文件,<param name="DatePattern" value="'.'yyyy-MM-dd" />表示每天深夜时会自动复制daily_system.log的内容生成一个名如daily_system.log.2008-08-07的日志文件
-----------------------------------------------------------------------------------------------------------------------
下面再解释一些共用的设置参数:
<param name="File" value="../log/system.log" />表示生成的日志文件保存的目录与名称
<param name="Append" value="false" />false表示重启程序之后,不会把日志添加到文件末尾,取而代之是清空原来日志,写入新的日志.true则是会把新日志添加到文件末尾
<param name="Threshold" value="info" />表示这个appender只显示value以上级别的日志
<layout class="org.apache.log4j.PatternLayout">表示所用的日志外观,即我们的日志要以何种格式显示出来
----------------------------------------------------------------------------------------------------------------------
<logger name="net.blogjava.itvincent">
<level value="debug"/>
<appender-ref ref="DEBUG_FILE"/>
</logger>
表示DEBUG_FILE这个appender,会显示所有为net.blogjava.itvincent开头的日志名称的debug信息
<root>
<level value="info"/>
<appender-ref ref="CONSOLE" />
<appender-ref ref="FILE" />
<appender-ref ref="DEBUG_HTML"/>
<appender-ref ref="DAILYFILE"/>
</root>
表示在根日志器中加入CONSOLE、FILE、DEBUG_HTML、DAILYFILE这四个appender
要使日志生效,就要通过上面两种方式加入appender
---------------------------------------------------------------------------------------------------------
Java类中插入以下成员变量:
private static Logger log = LoggerFactory.getLogger(Sample.class);
欢迎回复回信交流!