log4j2日志配置例子

1 篇文章 0 订阅

参考

Log4j2的Policy触发策略与Strategy滚动策略配置详解
https://blog.csdn.net/ThinkWon/article/details/101628222
https://blog.csdn.net/shiyong1949/article/details/54666992

例子

druid 网站
https://github.com/alibaba/druid/wiki/Druid%E4%B8%AD%E4%BD%BF%E7%94%A8log4j2%E8%BF%9B%E8%A1%8C%E6%97%A5%E5%BF%97%E8%BE%93%E5%87%BA

其他

配置示例一
按日志级别切分

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

	<appender name="infoLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/p-contract-mis/info.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{traceId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="info"/>
			<param name="levelMax" value="info"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>
	<appender name="warnLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/p-contract-mis/warn.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{traceId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="warn"/>
			<param name="levelMax" value="warn"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>
	<appender name="errorLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/p-contract-mis/error.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{traceId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="error"/>
			<param name="levelMax" value="error"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>

	<logger name="org">
		<level value="info"/>
	</logger>
	<logger name="com">
		<level value="info"/>
	</logger>

	<root>
		<appender-ref ref="infoLog"/>
		<appender-ref ref="warnLog"/>
		<appender-ref ref="errorLog"/>
	</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 class="org.apache.log4j.ConsoleAppender" name="stdout">
        <layout class="org.apache.log4j.PatternLayout">
            <param value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{traceId}]-[%l] %m%n"
                   name="ConversionPattern"/>
        </layout>
    </appender>

    <logger name="org">
        <level value="info"/>
    </logger>
    <logger name="com">
        <level value="info"/>
    </logger>
    <root>
        <level value="info"/>
        <appender-ref ref="stdout"/>
    </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 class="org.apache.log4j.ConsoleAppender" name="stdout">
		<layout class="org.apache.log4j.PatternLayout">
			<param value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{PtxId}]-[%l] %m%n"
				   name="ConversionPattern"/>
		</layout>
	</appender>

	<appender name="infoLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/${project.name}/info.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{PtxId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="info"/>
			<param name="levelMax" value="info"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>
	<appender name="warnLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/${project.name}/warn.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{PtxId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="warn"/>
			<param name="levelMax" value="warn"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>
	<appender name="errorLog" class="org.apache.log4j.DailyRollingFileAppender">
		<param name="File" value="/logs/${project.name}/error.log"/>
		<param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern"
				   value="%d{yyyy-MM-dd HH:mm:ss} [%p]-[%t]-[%X{PtxId}]-[%l] %m%n"/>
		</layout>
		<!--过滤器设置输出的级别-->
		<filter class="org.apache.log4j.varia.LevelRangeFilter">
			<param name="levelMin" value="error"/>
			<param name="levelMax" value="error"/>
			<param name="AcceptOnMatch" value="true"/>
		</filter>
	</appender>

	<logger name="org">
		<level value="info"/>
	</logger>
	<logger name="com">
		<level value="info"/>
	</logger>

	<root>
		<level value="info"/>
		<appender-ref ref="stdout"/>
		<appender-ref ref="infoLog"/>
		<appender-ref ref="warnLog"/>
		<appender-ref ref="errorLog"/>
	</root>
</log4j:configuration>

例子

Log4j2的Policy触发策略与Strategy滚动策略配置详解

ThinkWon 2019-09-28 18:13:24 3171 收藏
展开
文章目录
Policy触发策略
SizeBasedTriggeringPolicy
CronTriggeringPolicy
TimeBasedTriggeringPolicy
Strategy滚动策略
Policy是用来控制日志文件何时(When)进行滚动的;Strategy是用来控制日志文件如何(How)进行滚动的。

如果配置的是RollingFile或RollingRandomAccessFile,则必须配置一个Policy。

Policy触发策略
SizeBasedTriggeringPolicy
基于日志文件大小的触发策略。单位有:KB,MB,GB

1 CronTriggeringPolicy 基于Cron表达式的触发策略,很灵活。 1 TimeBasedTriggeringPolicy 基于时间的触发策略。该策略主要是完成周期性的log文件封存工作。有两个参数:

interval,integer型,指定两次封存动作之间的时间间隔。这个配置需要和filePattern结合使用,filePattern日期格式精确到哪一位,interval也精确到哪一个单位。注意filePattern中配置的文件重命名规则是%d{yyyy-MM-dd HH-mm-ss}-%i,最小的时间粒度是ss,即秒钟。
TimeBasedTriggeringPolicy默认的size是1,结合起来就是每1秒钟生成一个新文件。如果改成%d{yyyy-MM-dd HH},最小粒度为小时,则每一个小时生成一个文件

modulate,boolean型,说明是否对封存时间进行调制。若modulate=true, 则封存时间将以0点为边界进行偏移计算。比如,modulate=true,interval=4hours, 那么假设上次封存日志的时间为03:00,则下次封存日志的时间为04:00, 之后的封存时间依次为08:00,12:00,16:00

简单示例:

<?xml version="1.0" encoding="UTF-8"?> 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 Strategy滚动策略 DefaultRolloverStrategy

默认滚动策略

常用参数:max,保存日志文件的最大个数,默认是7,大于此值会删除旧的日志文件。

1 2 DirectWriteRolloverStrategy

日志直接写入由文件模式表示的文件。

这两个Strategy都是控制如何进行日志滚动的,平时大部分用DefaultRolloverStrategy就可以了。
————————————————
版权声明:本文为CSDN博主「ThinkWon」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ThinkWon/article/details/101628222

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值