SpringBoot+Slf4j+Log4j2+mybatis 日志整合

注:本次使用的是springboot4,具体版本为springboot4.0.6 GA (正式版)

Slf4j为外部调用提供了统一的日志接口,其内部实现取决于使用的日志框架。Slf4j是门面模式的优秀实践。

目的是要将这四部分进行整合,即希望日志都通过Log4j2来进行打印/记录。

1)引入依赖(不知道这几个依赖是否有多余的,这四个一起是能正常实现,少一个多一个没验证过):

复制代码
<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>2.0.18</version>
			<scope>compile</scope>
		</dependency>
		<!-- Source: https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-slf4j2-impl -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-slf4j2-impl</artifactId>
			<version>2.26.0</version>
			<scope>compile</scope>
			<exclusions>
				<exclusion>
					<groupId>org.apache.logging.log4j</groupId>
					<artifactId>log4j-api</artifactId>
				</exclusion>
				<exclusion>
					<groupId>org.apache.logging.log4j</groupId>
					<artifactId>log4j-core</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<!-- Source: https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-core</artifactId>
			<version>2.26.0</version>
			<exclusions>
				<exclusion>
					<groupId>org.apache.logging.log4j</groupId>
					<artifactId>log4j-api</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<!-- Source: https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-api -->
		<dependency>
			<groupId>org.apache.logging.log4j</groupId>
			<artifactId>log4j-api</artifactId>
			<version>2.26.0</version>
			<scope>compile</scope>
		</dependency>

上面依赖包括:slf4j-api、log4j-slf4j2-impl、log4j-api、log4j-core

需要注意的是,要排除多余依赖,不一定要按下面写的来排除,上面四个依赖只要是唯一的就行。我的依赖排除如下:

log4j-slf4j2-impl依赖中,排除log4j-api和log4j-core;

log4j-core依赖中,排除log4j-api;

另外,spring-boot-starter依赖中,要排除spring-boot-starter-logging。

ps:还可以使用另一种依赖 spring-boot-starter-log4j2 代替,具体实操没有,但理论可行。

2)mybatis-config.xml配置-实现sql日志通过log4j2的打印

复制代码
    <settings>
        <setting name="logImpl" value="SLF4J"/>
    </settings>

3)log4j2.xml配置-精细化控制log4j2的日志使用

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="info">
    <properties>
        <property name="LOG_HOME">D:/logs</property>
        <property name="FILE_NAME">mylog</property>
        <property name="log.sql.level">debug</property>
    </properties>


    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] LOG4J2 %-5level %l - %msg%n"/>
        </Console>

        <RollingRandomAccessFile name="RollingRandomAccessFile"
                                 fileName="C:\Users\aaa\Desktop\testlog/log4j2-config.xml.log"
                                 filePattern="C:\Users\aaa\Desktop\testlog/%d{yyyy-MM-dd}/log4j2-config.xml-%i.log">
        <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] LOG4J2 %-5level %l - %msg%n"/>
        <Policies>
            <TimeBasedTriggeringPolicy interval="1"/>
            <SizeBasedTriggeringPolicy size="10 MB"/>
        </Policies>
        <DefaultRolloverStrategy max="20"/>
    </RollingRandomAccessFile>
</Appenders>

<Loggers>
    <Root level="info">
        <AppenderRef ref="Console"/>
        <AppenderRef ref="RollingRandomAccessFile"/>
    </Root>

    <Logger name="com.example.dao.EmpDao" level="${log.sql.level}" additivity="false">
        <AppenderRef ref="Console"/>
    </Logger>
</Loggers>
</Configuration>

经过以上三个步骤,即可实现log4j2日志框架的使用。

相关推荐
lfwh2 小时前
探针程序技术解析:基于 Spring Boot 非 Web 模式的云服务监控告警系统
前端·spring boot·后端
霸道流氓气质3 小时前
阿里云 OSS 从零到实战:概念、配置与 Spring Boot 集成指南
数据库·spring boot·阿里云
可乐ea3 小时前
【Spring Boot + MyBatis|第4篇】MyBatis 动态 SQL:if、where、foreach 使用详解
java·spring boot·后端·sql·mybatis
布局呆星4 小时前
Spring Boot + Redis 缓存实战:@Cacheable、序列化踩坑、缓存一致性,一次讲透
spring boot·redis·缓存
Devin~Y5 小时前
大厂 Java 面试实战:从 Spring Boot 微服务到 AI RAG 音视频平台全链路解析
java·spring boot·redis·spring cloud·微服务·rag·spring ai
我登哥MVP5 小时前
SpringCloud 核心组件解析:服务注册与发现
java·spring boot·后端·spring·spring cloud·java-ee·maven
_未闻花名_5 小时前
PostgreSQL的若干扩展安装和使用
spring boot·postgresql·postgis·timescaledb·pg_cron·pgmq·zhparser
砍材农夫6 小时前
物联网实战:Spring Boot + Netty 搭建 MQTT 统一接入层
java·网络·spring boot·后端·物联网·spring
写代码的小阿帆6 小时前
英语四六级证书审核(SpringBoot+Dify+RPA)
java·spring boot