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日志框架的使用。

相关推荐
Flittly2 天前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
人活一口气2 天前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
考虑考虑3 天前
Mybatis实现批量插入
java·后端·mybatis
Java陈序员3 天前
企业级!一个基于 Java 开发的开源 AI 应用开发平台!
spring boot·agent·mcp
杨运交3 天前
[041][公共模块]分布式唯一ID生成器设计与实现:一款灵活可扩展的雪花算法框架
spring boot
Flittly4 天前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
Flynt5 天前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
掉鱼的猫6 天前
Spring Boot → Solon 注解迁移实战指南:一张对照表说清楚
java·spring boot
人活一口气7 天前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
java小白小10 天前
SpringBoot(01): 初识SpringBoot,从Spring的痛点说起
spring boot