1. 首先引入所需的依赖 (2.16.0版本的log4j2)
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.32</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-jul</artifactId>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
</dependency>
<!-- +++++++++++++++++++++++ 日志 log4j start +++++++++++++++++++++++ -->
2. 第二步创建 src/main/resources/log4j2.xml 定义自己的日志格式和输入文件目录
<?xml version="1.0" encoding="UTF-8"?>
<configuration status="OFF" monitorInterval="1800">
<Properties>
<property name="LOG_PATTERN" value="[ %date{yyyy-MM-dd HH:mm:ss.SSS} ] [ %thread ] %-5level %logger{36} - %msg%n" />
<property name="FILE_NAME" value="admin" />
<property name="FILE_PATH" value="/data/logs/" />
</Properties>
<appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="${LOG_PATTERN}"/>
</Console>
<RollingFile name="RollingFileInfo" fileName="${FILE_PATH}/${FILE_NAME}/${FILE_NAME}_info.log"
filePattern="${FILE_PATH}/${FILE_NAME}-INFO-%d{yyyy-MM-dd-HH}_%i.log.gz">
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="${LOG_PATTERN}"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="10MB"/>
</Policies>
<DefaultRolloverStrategy max="15"/>
</RollingFile>
<RollingFile name="RollingFileError" fileName="${FILE_PATH}/${FILE_NAME}/${FILE_NAME}_error.log"
filePattern="${FILE_PATH}/${FILE_NAME}-ERROR-%d{yyyy-MM-dd-HH}_%i.log.gz">
<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="${LOG_PATTERN}"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="10MB"/>
</Policies>
<DefaultRolloverStrategy max="15"/>
</RollingFile>
</appenders>
<loggers>
<!-- 此处 定义到Mapper接口所在的包路径即可 也可指定某个文件的日志级别-->
<logger name="com.shan.hero.admin.mapper" level="DEBUG" additivity="false">
<AppenderRef ref="Console"/>
</logger>
<!-- 此处指定 整个的 日志级别 info -->
<root level="info">
<appender-ref ref="Console"/>
<appender-ref ref="RollingFileInfo"/>
<appender-ref ref="RollingFileError"/>
</root>
</loggers>
</configuration>
展示:
[ 2021-12-17 17:50:41.830 ] [ main ] DEBUG com.shan.hero.admin.mapper.product.ProductMapper.selectTypes – ==> Preparing: select * from prod_type where status = 1 order by type asc
[ 2021-12-17 17:50:41.843 ] [ main ] DEBUG com.shan.hero.admin.mapper.product.ProductMapper.selectTypes – ==> Parameters:
[ 2021-12-17 17:50:41.892 ] [ main ] DEBUG com.shan.hero.admin.mapper.product.ProductTypeMapper.selectTypes – <== Total: 567
[ 2021-12-17 17:50:41.911 ] [ main ] INFO com.shan.hero.admin.config.ShanCacheConfig – init-server-dataMap-{“101”:[{“code”:”10101″,”name”:”家用电器”,”parentCode”:”101″,”parentId”:0,”ptId”:1,

版权声明:本文为weixin_42247563原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。