Spring Boot集成SLF4j详解(springboot集成knife4j)
lipiwang 2025-06-09 23:26 2 浏览 0 评论
Spring Boot 集成 SLF4j 详解:从基础到高级实践
SLF4j(Simple Logging Facade for Java)是一个日志门面框架,提供统一的日志接口,允许开发者灵活切换底层日志实现(如 Logback、Log4j2 等)。Spring Boot 默认集成 Logback 作为日志实现,但通过 SLF4j 门面,开发者可以无缝切换其他日志框架。以下从基础到高级实践逐步解析。
1. 基础配置:Spring Boot 默认日志
1.1 依赖引入
Spring Boot Starter 默认包含
spring-boot-starter-logging(基于 Logback),无需显式添加:
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
1.2 日志输出
在代码中通过 @Slf4j(Lombok 注解)或手动创建 Logger 对象:
java
import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Slf4j
public class DemoController {
// 手动创建(若无 Lombok)
private static final Logger logger = LoggerFactory.getLogger(DemoController.class);
public void logExample() {
log.info("This is an INFO message");
log.error("This is an ERROR message");
}
}
1.3 配置文件
在 application.properties 或 application.yml 中配置日志级别、输出格式等:
properties
# 设置全局日志级别
logging.level.root=INFO
logging.level.com.example.demo=DEBUG
# 输出到文件(默认追加到当前目录)
logging.file.name=app.log
# 控制台输出格式
logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} - %msg%n
# 文件输出格式
logging.pattern.file=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} - %msg%n
2. 高级配置:切换日志框架
2.1 切换为 Log4j2
- 排除默认 Logback 依赖:
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
- 添加 Log4j2 依赖:
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
- 配置 log4j2.xml:
xml
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/>
</Console>
</Appenders>
<Loggers>
<Root level="INFO">
<AppenderRef ref="Console"/>
</Root>
</Loggers>
</Configuration>
3. 高级实践:自定义与优化
3.1 日志分组
在 application.properties 中定义日志组,统一管理相关类的日志级别:
properties
logging.group.custom=com.example.service,com.example.dao
logging.level.custom=DEBUG
3.2 Profile 特定配置
根据不同环境(如 dev/prod)配置日志:
yaml
# application-dev.yml
logging:
level:
root: DEBUG
file:
name: dev.log
# application-prod.yml
logging:
level:
root: WARN
file:
name: prod.log
3.3 异步日志(提升性能)
以 Log4j2 为例,配置异步 Appender:
xml
<!-- log4j2.xml -->
<Configuration>
<Appenders>
<Async name="AsyncAppender">
<AppenderRef ref="Console"/>
</Async>
</Appenders>
<Loggers>
<Root level="INFO">
<AppenderRef ref="AsyncAppender"/>
</Root>
</Loggers>
</Configuration>
3.4 使用 MDC(Mapped Diagnostic Context)
在分布式系统中追踪请求链路:
java
import org.slf4j.MDC;
public class DemoController {
public void handleRequest() {
MDC.put("requestId", UUID.randomUUID().toString());
log.info("Request started");
// 业务逻辑
MDC.clear();
}
}
日志格式中添加 %X{requestId}:
properties
logging.pattern.console=%d{yyyy-MM-dd} [%X{requestId}] %msg%n
4. 常见问题与最佳实践
4.1 避免日志漏洞
- 敏感信息脱敏:禁止在日志中输出密码、Token 等。
- 防注入攻击:对用户输入内容进行转义。
4.2 日志性能优化
- 使用占位符 {} 代替字符串拼接:
java
log.debug("User {} logged in at {}", username, LocalDateTime.now());
- 避免高频日志:在循环内谨慎使用 DEBUG 级别。
4.3 日志文件管理
- 滚动归档(Logback 示例):
xml
<!-- logback-spring.xml -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>app.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>app-%d{yyyy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
总结
通过 SLF4j,Spring Boot 实现了日志接口与实现的解耦。开发者可以灵活配置日志级别、格式、输出目标,并通过高级特性(如异步日志、MDC)提升系统可维护性和性能。结合环境隔离和最佳实践,可构建高效、安全的日志体系。
相关推荐
- Java 实体映射工具 MapStruct(jpa实体类映射类)
-
简介:让你的DO(业务实体对象),DTO(数据传输对象)数据转换更简单强大前言在软件架构中,分层式结构是最常见,各层之间有其独立且隔离的业务逻辑,也因而各层有自己的输入输出对象,也就是代码中见到各...
- @Date不管用怎么办,想少写get和setter方法,怎么办
-
学习交流群:293911833,有遇到问题的,可以加一下群,大家互相交流,一起进步今天在使用lombok的时候,为什么@Date不管用,是我映射没做好吗?还是其他的,后来查了一些大佬的资料终于找到问...
- Spring系列之集成MongoDB的2种方法
-
MongoDB是最流行的NoSQL数据库,SpringBoot是使用Spring的最佳实践。今天带大家讲一讲SpringBoot集成MongoDB的两种方式,MongoDB的安装自行去官网查询,本地开...
- Spring Boot集成SLF4j详解(springboot集成knife4j)
-
SpringBoot集成SLF4j详解:从基础到高级实践SLF4j(SimpleLoggingFacadeforJava)是一个日志门面框架,提供统一的日志接口,允许开发者灵活切换底层...
- 自定义代码生成器(上)(代码自动生成器)
-
1概述1.1介绍在项目开发过程中,有很多业务模块的代码是具有一定规律性的,例如controller控制器、service接口、service实现类、mapper接口、model实体类等等,这部分代...
- Java系统开发从入门到精通第四讲(文字版)
-
课程目标:了解重要的JavaAPI和一些必备框架的使用,这些都是系统开发的标配需要掌握日期时间APIJava8通过发布新的Date-TimeAPI(JSR310)来进一步加强对日期与时间...
- 重拾JAVA:这种编程语言为什么不行了?
-
全文共2322字,预计学习时长6分钟为了应对新工作,笔者在过去两周一直在重新熟悉一位老朋友:JAVA。我以JAVA开启了我的软件事业,与之共行了两年半左右的时间。但是随着容器和微服务的出现,JAVA很...
- 一款提高Java开发效率的工具(java怎么提高技术)
-
今天来介绍一款Java常用插件:Lombokhttps://projectlombok.org/通常在用Java代码开发项目过程中,都会建立各种各种的Bean类,如下:publicclassSea...
- JDK从8升级到21的问题集(jdk1.6升级到1.8要考虑的因素)
-
一、背景与挑战1.升级动因oOracle长期支持策略o现代特性需求:协程、模式匹配、ZGC等o安全性与性能的需求oAI新技术引入的版本要求2.项目情况o100+项目并行升级的协同作战o多技术栈并存o持...
- Lombok:让Java代码变得优雅简洁的秘密武器
-
Lombok:让Java代码变得优雅简洁的秘密武器在Java的世界里,代码量往往是一个开发者幸福感的重要衡量指标。代码写得越少,出错的可能性就越小,同时维护起来也更轻松。而Lombok正是这样一个让J...
- SpringToolSuite(STS)安装lombok插件
-
一、打开maven仓库,找到lombok所在的文件夹二、在命令行中运行java-jarlombok-1.18.20.jar,打开lombok插件安装的可视化界面。三、选择STS安装目录,点击Ins...
- 年末将至,Java 开发者必须了解的 15 个Java 顶级开源项目
-
专注于Java领域优质技术,欢迎关注作者:SnailClimbStar的数量统计于2019-12-29。1.JavaGuideGuide哥大三开始维护的,目前算是纯Java类型项目中Sta...
- 相见恨晚,一个架构师也不会用的Lombok注解
-
原创:不羡鸳鸯不羡仙,一行代码调半天。小姐姐味道(微信公众号ID:xjjdog),欢迎分享,转载请保留出处。我见过很多反对Lombok的同学,背地里又偷偷的把插件添加了进去,这是真香原理在搞鬼。嘴上说...
- 第二弹!安排!安利几个让你爽到爆的IDEA必备插件
-
作者:Guide哥来自:JavaGuide大家好,我是Guide哥。上一篇关于IDEA插件推荐的文章:《第一弹!安排!安利10个让你爽到爆的IDEA必备插件!》收到了很多小伙伴的好评,时隔大半个月...
- Java @Data注解(java @order注解)
-
1、@Data注解是lombok.jar包下的注解,该注解通常用在实体bean上,不需要写出set和get方法,但是具备实体bean所具备的方法,简化编程提高变成速度。2、@Data相当于@Gette...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- maven镜像 (69)
- undefined reference to (60)
- zip格式 (63)
- oracle over (62)
- date_format函数用法 (67)
- 在线代理服务器 (60)
- shell 字符串比较 (74)
- x509证书 (61)
- localhost (65)
- java.awt.headless (66)
- syn_sent (64)
- settings.xml (59)
- 弹出窗口 (56)
- applicationcontextaware (72)
- my.cnf (73)
- httpsession (62)
- pkcs7 (62)
- session cookie (63)
- java 生成uuid (58)
- could not initialize class (58)
- beanpropertyrowmapper (58)
- word空格下划线不显示 (73)
- jar文件 (60)
- jsp内置对象 (58)
- makefile编写规则 (58)