- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
- <log4j:configurationxmlns:log4j='http://jakarta.apache.org/log4j/'>
- <appendername="myConsole"class="org.apache.log4j.ConsoleAppender">
- <layoutclass="org.apache.log4j.PatternLayout">
- <paramname="ConversionPattern"
- value="[%d{dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\} - %m%n"/>
- </layout>
- <!--过滤器设置输出的级别-->
- <filterclass="org.apache.log4j.varia.LevelRangeFilter">
- <paramname="levelMin"value="debug"/>
- <paramname="levelMax"value="warn"/>
- <paramname="AcceptOnMatch"value="true"/>
- </filter>
- </appender>
- <appendername="myFile"class="org.apache.log4j.RollingFileAppender">
- <paramname="File"value="D:/output.log"/><!-- 设置日志输出文件名 -->
- <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
- <paramname="Append"value="true"/>
- <paramname="MaxBackupIndex"value="10"/>
- <layoutclass="org.apache.log4j.PatternLayout">
- <paramname="ConversionPattern"value="%p (%c:%L)- %m%n"/>
- </layout>
- </appender>
- <appendername="activexAppender"class="org.apache.log4j.DailyRollingFileAppender">
- <paramname="File"value="E:/activex.log"/>
- <paramname="DatePattern"value="'.'yyyy-MM-dd'.log'"/>
- <layoutclass="org.apache.log4j.PatternLayout">
- <paramname="ConversionPattern"
- value="[%d{MMdd HH:mm:ss SSS\} %-5p] [%t] %c{3\} - %m%n"/>
- </layout>
- </appender>
- <!-- 指定logger的设置,additivity指示是否遵循缺省的继承机制-->
- <loggername="com.runway.bssp.activeXdemo"additivity="false">
- <priorityvalue ="info"/>
- <appender-refref="activexAppender"/>
- </logger>
- <!-- 根logger的设置-->
- <root>
- <priorityvalue ="debug"/>
- <appender-refref="myConsole"/>
- <appender-refref="myFile"/>
- </root>
- </log4j:configuration>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/' > <appender name="myConsole" class="org.apache.log4j.ConsoleAppender"> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\} - %m%n" /> </layout> <!--过滤器设置输出的级别--> <filter class="org.apache.log4j.varia.LevelRangeFilter"> <param name="levelMin" value="debug" /> <param name="levelMax" value="warn" /> <param name="AcceptOnMatch" value="true" /> </filter> </appender> <appender name="myFile" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="D:/output.log" /><!-- 设置日志输出文件名 --> <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 --> <param name="Append" value="true" /> <param name="MaxBackupIndex" value="10" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%p (%c:%L)- %m%n" /> </layout> </appender> <appender name="activexAppender" class="org.apache.log4j.DailyRollingFileAppender"> <param name="File" value="E:/activex.log" /> <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%d{MMdd HH:mm:ss SSS\} %-5p] [%t] %c{3\} - %m%n" /> </layout> </appender> <!-- 指定logger的设置,additivity指示是否遵循缺省的继承机制--> <logger name="com.runway.bssp.activeXdemo" additivity="false"> <priority value ="info"/> <appender-ref ref="activexAppender" /> </logger> <!-- 根logger的设置--> <root> <priority value ="debug"/> <appender-ref ref="myConsole"/> <appender-ref ref="myFile"/> </root> </log4j:configuration>
(1). 输出方式appender一般有5种:
org.apache.log4j.RollingFileAppender(滚动文件,自动记录最新日志)
org.apache.log4j.ConsoleAppender (控制台)
org.apache.log4j.FileAppender (文件)
org.apache.log4j.DailyRollingFileAppender (每天产生一个日志文件)
org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方)
(2). 日记记录的优先级priority,优先级由高到低分为
OFF ,FATAL ,ERROR ,WARN ,INFO ,DEBUG ,ALL。
Log4j建议只使用FATAL ,ERROR ,WARN ,INFO ,DEBUG这五个级别。
(3). 格式说明layout中的参数都以%开始,后面不同的参数代表不同的格式化信息(参数按字母表顺序列出):
%c 输出所属类的全名,可在修改为 %d{Num} ,Num类名输出的维(如:"org.apache.elathen.ClassName",%C{2}将输出elathen.ClassName)
%d 输出日志时间其格式为 %d{yyyy-MM-dd HH:mm:ss,SSS},可指定格式 如 %d{HH:mm:ss}
%l 输出日志事件发生位置,包括类目名、发生线程,在代码中的行数
%n 换行符
%m 输出代码指定信息,如info(“message”),输出message
%p 输出优先级,即 FATAL ,ERROR 等
%r 输出从启动到显示该log信息所耗费的毫秒数
%t 输出产生该日志事件的线程名
${catalina.home}/logs/errors.log 可保存到tomcat中的logs文件中 若用${catalina.base}则保存到tomcat中的bin文件夹中 具体配置可参考:http://xuxu366.iteye.com/blog/109144 这个示例:包括log4j.xml和log4j.properties两种格式的方法 注:log4j.xml文件的方法不需再写入util properties方法需要另写util的方法 这两个哪一个性能更好一点,有待探究!
xml文件 | |||
编号 | 配置项 | 配置项描述 | 示例 |
1 | threshold | 阈值项 | <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false" threshold="null"> |
2 | root | 根日志属性项 | <root> <priority value="info"/> <appender-ref ref="CONSOLE"/> </root> |
3 | priority | 级别项(旧) | <priority value="info"/> |
4 | level | 级别项(新) | <level value="info"/> |
5 | category | 子日志属性项(旧) | <category additivity="true" name="com.eos.log"> |
6 | logger | 子日志属性项(新) | <logger additivity="true" name="com.eos"> |
7 | appender-ref | 输出端控制项 | <appender-ref ref="CONSOLE"/> |
8 | additivity | appender是否继承设置 | <logger additivity="true" name="com.eos"> |
9 | appender | 输出目的地定义项 | <appender class="org.apache.log4j.ConsoleAppender" name="CONSOLE"> |
10 | layout | 输出格式定义项 | <layout class="org.apache.log4j.PatternLayout"> |