学习 http://www.iteye.com/topic/378077
http://www.codeceo.com/article/log4j-usage.html
http://blog.youkuaiyun.com/guoquanyou/article/details/5689652 关于输出格式控制
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“rn”,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)
<?xml version="1.0" encoding="gbk" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!-- 定义名为stdout输出到控制台的Appender -->
<appender name="stdout" class="org.apache.log4j.ConsoleAppender">
<!-- 定义该Appender对应的Layout -->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%r %d [%t] %-p %c %x - #%l# - %m%n"/>
</layout>
</appender>
<!-- 定义名为logfile输出到日志文件的Appender,每天一个日志文件 -->
<appender name="logfile" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="log23.log"/>
<!-- 是否采用将日志追加到已有的日志文件之后 -->
<param name="Append" value="true"/>
<!-- 定义日期格式 -->
<param name="DatePattern" value=".yyyy-MM-dd"/>
<!-- 定义该Appender对应的Layout -->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value=" %r %d %p [%c] - %m%n"/>
</layout>
</appender>
<!-- 该Logger将对lee包、及其所有子包之内的Logger起作用 -->
<logger name="kx0">
<!-- 输出debug及其更高级别的日志 -->
<level value="error"/>
<!-- 将日志同时输出到控制台和日志文件 -->
<appender-ref ref="stdout"/>
<appender-ref ref="logfile"/>
</logger>
<!-- 指定日志级别,引用哪些Appender -->
<root>
<!-- 输出info及其更高级别的日志 -->
<level value="error"/>
<!-- 将日志同时输出到控制台和日志文件 -->
<appender-ref ref="stdout"/>
<appender-ref ref="logfile"/>
</root>