Log4j xml 配置方式

原文链接:http://blog.csdn.net/johnnycode/article/details/44538895

1、支持不同日志级别输出到不同的文件

2、支持过滤第三方包

web.xml 配置信息,因为本文使用Spring,相关信息请自行参考!

	<!-- 配置 Log4j -->
	<context-param>
		<param-name>webAppRootKey</param-name>
		<param-value>myWebApp.root</param-value>
	</context-param>
	<context-param>
		<param-name>log4jConfigLocation</param-name>
		<param-value>classpath:log4j.xml</param-value>
	</context-param>
	<!-- 开一条watchdog线程每60秒扫描一下配置文件的变化 -->
	<context-param>
		<param-name>log4jRefreshInterval</param-name>
		<param-value>60000</param-value>
	</context-param>
	<listener>
		<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
	</listener>

log4j.xml 配置信息

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
	<!-- STDOUT 级别配置 -->
	<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
		<param name="encoding" value="UTF-8" />
		<param name="target" value="System.out" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="[%-5p %d{HH:mm:ss}] %c - %m%n" />
		</layout>
	</appender>
	<!-- ALL 级别配置 -->
	<appender name="ALL" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="encoding" value="UTF-8" />
		<param name="File" value="${myWebApp.root}/logs/all.log" />
		<param name="Append" value="true" />
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="[%-5p %d{yyyy-MM-dd HH:mm:ss}] %c - %m%n" />
		</layout>
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="LevelMin" value="DEBUG" />
			<param name="LevelMax" value="ERROR" />
		</filter>
	</appender>
	<!-- ERROR 级别配置 -->
	<appender name="ERROR" class="org.apache.log4j.RollingFileAppender">
		<param name="File" value="${myWebApp.root}/logs/error.log" />
		<param name="Append" value="true" />
		<param name="MaxFileSize" value="50MB" />
		<param name="MaxBackupIndex" value="1000" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="[%-5p %d{yyyy-MM-dd HH:mm:ss}] %c - %m%n" />
		</layout>
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="LevelMin" value="ERROR" />
			<param name="LevelMax" value="ERROR" />
		</filter>
	</appender>
	<!-- category 定义第三方过滤条件 -->
	<category name="org.springframework">
		<priority value="warn" />
		<appender-ref ref="ALL" />
	</category>
	<category name="org.hibernate">
		<priority value="debug" />
		<appender-ref ref="ALL" />
	</category>
	<root>
		<appender-ref ref="STDOUT" />
		<appender-ref ref="ALL" />
		<appender-ref ref="ERROR" />
	</root>
</log4j:configuration>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
log4j是Java广泛使用的日志框架之一,它允许开发人员以各种方式记录应用程序的输出,从而帮助调试和故障排除。以下是log4jXML配置说明: 1. 首先,需要定义一个根logger,它将捕获所有日志消息。可以通过设置级别(level)属性来控制要记录的日志消息的详细程度。例如,设置级别为INFO将记录INFO、WARN、ERROR和FATAL级别的日志消息。 ``` <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false"> <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> <level value="INFO"/> <appender-ref ref="console"/> </root> </log4j:configuration> ``` 2. 可以通过定义一个或多个logger来为特定的类或包设置日志级别。例如,以下配置将为名为com.example.MyClass的类设置DEBUG级别的日志记录: ``` <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false"> <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> <logger name="com.example.MyClass"> <level value="DEBUG"/> </logger> <root> <level value="INFO"/> <appender-ref ref="console"/> </root> </log4j:configuration> ``` 3. 可以使用不同的appender来将日志消息输出到不同的位置,例如,控制台、文件、数据库等。以下配置将同时将日志消息输出到控制台和名为myFile的文件: ``` <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false"> <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> <appender name="myFile" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="mylog.log"/> <param name="MaxFileSize" value="100KB"/> <param name="MaxBackupIndex" value="1"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n"/> </layout> </appender> <logger name="com.example.MyClass"> <level value="DEBUG"/> <appender-ref ref="myFile"/> </logger> <root> <level value="INFO"/> <appender-ref ref="console"/> <appender-ref ref="myFile"/> </root> </log4j:configuration> ``` 这是基本的log4jXML配置说明,可以根据需求进行灵活配置
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值