6、log4j2的RollingFile标签

第一步:添加依赖

<project xmlns="http://maven.apache.org/POM/4.0.0"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.example</groupId>
	<artifactId>logging-test</artifactId>
	<version>0.0.1-SNAPSHOT</version>

	<properties>
		<maven.compiler.source>8</maven.compiler.source>
		<maven.compiler.target>8</maven.compiler.target>
	</properties>

	<dependencies>
		<dependency>
			<artifactId>junit</artifactId>
			<groupId>junit</groupId>
			<version>4.12</version>
		</dependency>
		<!-- Log4j2 门面API -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-api</artifactId>
			<version>2.14.1</version>
		</dependency>
		<!-- Log4j2 日志实现 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-core</artifactId>
			<version>2.14.1</version>
		</dependency>
		<!--使用slf4j作为日志的门面,使用log4j2来记录日志 -->
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>1.7.30</version>
		</dependency> 
		<!--为slf4j绑定日志实现 log4j2的适配器 -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-slf4j-impl</artifactId>
			<version>2.12.1</version>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>3.8.1</version>
				<configuration>
					<source>${maven.compiler.source}</source>
					<target>${maven.compiler.target}</target>
					<encoding>UTF-8</encoding>
				</configuration>
			</plugin>
		</plugins>
	</build>
</project>

第二步:log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- monitorInterval="30"表示当修改了配置文件,我们不需要重启,它每30秒重新加载配置文件 -->
<Configuration status="WARN" monitorInterval="30">
	<Appenders>
		<Console name="Console" target="SYSTEM_OUT">
			<PatternLayout
				pattern="%d{HH:mm:ss} [%t] %-5level %logger{36} - %msg%n" />
		</Console>

		<File name="file" fileName="D://logs/myfile.log">
			<PatternLayout
				pattern="[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%-5level] %l %c{36} - %m%n" />
		</File>

		<RandomAccessFile name="accessFile"
			fileName="D://logs/myAcclog.log">
			<PatternLayout
				pattern="[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%-5level] %l %c{36} - %m%n" />
		</RandomAccessFile>

		<!--fileName 指定当前日志文件的位置和文件名称 
			filePattern指定当发生Rolling时,文件的转移和重命名规则 
			-->
		<RollingFile name="rollingFile" fileName="D://logs/myrollog.log" 
					filePattern="D:/logs/$${date:yyyy-MM-dd}/myrollog- %d{yyyy•MM-dd-HH-mm}-%i.log">
					
			<!-- 表示打印info级别以上的,该ThresholdFilter的操作表示对info级别以上的同意打印,不匹配的拒绝打印 -->
			<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />
			
			<!-- PatternLayout日志打印格式 -->
			<PatternLayout pattern="[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%-5level] %l %c{36} - %msg%n" />
			<Policies>
				<OnStartupTriggeringPolicy />
				<!-- 单个文件超过1KB,会转移旧文件去,旧文件格式是filePattern转换后的 -->
				<!--SizeBasedTriggeringPolicy 指定当文件体积大于size指定的值时,触发Rolling -->
				<SizeBasedTriggeringPolicy size="1 KB" />
				<!--TimeBasedTriggeringPolicy 这个配置需要和filePattern结合使用
					注意filePattern中配置的文件重命名规则是${FILE_NAME}-%d{yyyy-MM-dd HH-mm}-%i,最小的时间粒度是mm,即分钟。
					TimeBasedTriggeringPolicy指定的size是1,结合起来就是每1分钟生 成一个新文件。
					如果改成%d{yyyy-MM-dd HH},最小粒度为小时,则每一个小时生成一个文件。
				-->
				<TimeBasedTriggeringPolicy />
				
				<!-- 注意:该案例中使用的是%d{yyyy•MM-dd-HH-mm},表明每1分钟生成一个新的文件,
					当文件大小超过SizeBasedTriggeringPolicy设置的,则会在这一分钟内,也会生成新的文件,
					文件格式为myrollog-2022•01-16-14-52-1.log
							 myrollog-2022•01-16-14-52-2.log
							 myrollog-2022•01-16-14-52-3.log
							 ........
							 这样的
				 -->
			</Policies>
			<!-- 最大文件里只能保存30个 -->
			<DefaultRolloverStrategy max="30" />
		</RollingFile>
	</Appenders>
	<Loggers>
		<Root level="trace">
			<AppenderRef ref="Console" />
			<AppenderRef ref="rollingFile" />
		</Root>
	</Loggers>
</Configuration>

第三步:测试代码

package com.example.test;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class TestLog4j2 {

	private static final Logger LOGGER = LoggerFactory.getLogger(TestLog4j2.class);

	@Test
	public void testLog4j2() {
		while (true) {
			LOGGER.error("error");
			LOGGER.warn("warn");
			LOGGER.info("info");
			LOGGER.debug("debug");
			LOGGER.trace("trace");
		}
	}

}


在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值