springboot默认使用的日志框架是 Logback。如果你想使用log4j做日志框架需要排除掉Spring Boot默认的日志依赖spring-boot-starter-logging
,因为Spring Boot默认使用的是Logback。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
然后如果你需要异步添加日志,那么你还需要添加这个依赖
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.4.4</version> <!-- 确保使用的是与Log4j2兼容的Disruptor版本 -->
</dependency>
然后在application.properties文件中加入这行
#log4j配置
logging.config: classpath:log4j2.xml
然后在类路径下添加log4j2.xml的文件,内容是
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN" monitorInterval="30">
<!-- 全局属性定义,可用于Appender或Logger -->
<Properties>
<Property name="logBaseDir">../logs</Property>
<Property name="logPattern">[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%t] %-5p %c{1} - %m%n</Property>
</Properties>
<!-- Appenders定义 -->
<Appenders>
<!-- 控制台Appender -->
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="${logPattern}"/>
</Console>
<!-- 文件Appender,用于记录所有日志 -->
<File name="AllFile" fileName="${logBaseDir}/all.log">
<PatternLayout pattern="${logPattern}"/>
</File>
<!-- 滚动文件Appender,按日期和文件大小滚动 -->
<RollingFile name="RollingFile" fileName="${logBaseDir}/rolling.log"
filePattern="${logBaseDir}/$${date:yyyy-MM}/rolling-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout pattern="${logPattern}"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<SizeBasedTriggeringPolicy size="10MB"/>
</Policies>
<DefaultRolloverStrategy max="10"/>
</RollingFile>
</Appenders>
<!-- Loggers定义 -->
<Loggers>
<!-- 根Logger -->
<Root level="INFO">
<AppenderRef ref="Console"/>
<AppenderRef ref="AllFile"/>
<AppenderRef ref="RollingFile"/>
</Root>
<!-- 为特定包或类设置特定Logger -->
<Logger name="com.example" level="DEBUG" additivity="false">
<AppenderRef ref="RollingFile"/>
</Logger>
<!-- 异步Logger示例,提高性能 -->
<AsyncLogger name="com.example.async" level="INFO" includeLocation="true" additivity="false">
<AppenderRef ref="Console"/>
</AsyncLogger>
</Loggers>
</Configuration>
然后生成的日志就会保存到项目运行目录的同级目录下