新闻中心
logback.xml配置文件怎么写 Spring Boot日志配置
Spring Boot 默认使用 Logback,推荐配置 logback-spring.xml 以支持 Profile 和变量绑定;基础配置含控制台与按天滚动文件日志,可按环境(dev/prod)差异化设置,支持异步、包级控制、敏感信息过滤等定制。

Spring Boot 默认使用 Logback 作为日志框架,只需在 src/main/resources 下添加 logback-spring.xml(推荐)或 logback.xml,就能覆盖默认配置。优先用 logback-spring.xml,它支持 Spring Profile、变量绑定等增强特性。
基础结构:一个可运行的 logback-spring.xml
以下是最小可用配置,支持控制台输出 + 按天滚动文件日志:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!-- 引入 Spring Boot 默认的 base 配置(含 console appender 和基本格式)-->
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<include resource="org/springframework/boot/logging/logback/console-appender.xml"/>
<p><!-- 定义日志文件路径和名称 -->
<property name="LOG_PATH" value="./logs"/>
<property name="LOG_FILE" value="${LOG_PATH}/app.log"/></p><p><!-- 文件 Appender:按天滚动,保留 30 天,单文件不超过 100MB -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_FILE}</file>
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_PATH}/app.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggering
Policy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender></p><p><!-- 根 logger:控制整体日志级别和输出目标 -->
<root level="INFO">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
</configuration>按环境区分日志配置(用 springProfile)
利用 <springprofile></springprofile> 标签,不同 profile 加载不同设置:
DeepBrain
AI视频生成工具,ChatGPT +生成式视频AI =你可以制作伟大的视频!
146
查看详情
- 开发环境(dev):只输出到控制台,INFO 级别,带颜色
- 生产环境(prod):关闭控制台,启用压缩归档,更严格级别(如 WARN)
示例片段:
<springProfile name="dev">
<root level="INFO">
<appender-ref ref="CONSOLE"/>
</root>
</springProfile>
<p><springProfile name="prod">
<root level="WARN">
<appender-ref ref="FILE"/>
</root>
<!-- 可额外加异步 Appender 提升性能 -->
<appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
<appender-ref ref="FILE"/>
</appender>
</springProfile>常用自定义技巧
-
动态日志路径:用
${LOG_PATH:-./logs}设置默认值,避免空值报错 -
包级别日志控制:比如让 MyBatis 打印 SQL,在 root 下加:
<logger name="com.yourpackage.mapper" level="DEBUG" /> <logger name="org.mybatis.spring" level="DEBUG" />
-
过滤敏感信息:用
PatternLayoutEncoder配合自定义 converter,或用Filter拦截含密码的日志行 -
异步写日志:对 FILE appender 包一层
AsyncAppender,降低 I/O 对主线程影响
注意事项与调试建议
- 文件名必须是
logback-spring.xml才能启用 Spring 扩展;叫logback.xml会跳过 profile 支持 - 修改后重启应用才生效;开发时可加
debug="true"到 configuration 标签查看 Logback 加载过程 - 若日志没输出,检查 classpath 是否有多个 logback 配置,或是否被其他依赖(如 slf4j-simple)干扰
- 线上禁用
CONSOLEappender,避免 stdout/stderr 冲突或丢失
基本上就这些。不复杂但容易忽略细节——比如 profile 名要和 spring.profiles.active 一致,路径权限要确保应用可写,滚动策略参数大小写敏感(maxFileSize 不是 MaxFileSize)。配好之后,日志就稳了。
以上就是logback.xml配置文件怎么写 Spring Boot日志配置的详细内容,更多请关注其它相关文章!
# ai
# 配置文件
# 开发环境
# yy
# app
# 线上推广专业网站
# 橡塑网站推广热线
# 袜子的营销推广方案
# seo网络优化专员招聘网站
# 营销推广需要注意的问题
# 汉口网站seo优化
# 全网营销推广引流
# 社交化网络营销推广方案
# 芜湖三山区网站建设平台
# 网站建设平台如何办理
# 加载
# 上把
# 转成
# 绑定
# 转换为
# 转换成
# 自定义
# 用手
# 有什么
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
PDO预处理语句中冒号的正确处理:区分SQL函数格式与命名占位符
c++中的const_cast和reinterpret_cast怎么用_c++四种类型转换
Go语言中的*string:深入理解字符串指针
Win11怎么关闭快速启动_Win11彻底关机设置教程
天眼查企业查询官网入口 天眼查官方网页版查询
微博网页版首页入口 微博电脑端官网登录链接
QQ邮箱网页版邮箱入口 QQ邮箱官方登录平台
Win10如何恢复误删的快捷方式_Win10重建常用软件快捷方式
c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架
离线运行Go语言之旅:本地部署与GOPATH配置指南
Win11怎么隐藏桌面图标 Win11一键隐藏所有桌面元素及恢复显示
Sublime Text怎么设置垂直标尺_Sublime配置Rulers规范代码长度
Archive of Our Own官网直达 AO3最新可用地址一览
Safari自带网页翻译功能怎么用 无需插件轻松看懂外文网站【方法】
steam官方网页快速访问 steam账号注册全流程
Go与Ruby之间实现AES加密互通:CFB模式下的密钥长度匹配策略
汽水音乐车机版横屏版7.1 汽水音乐车机版横屏版下载入口
QQ邮箱官方邮箱登录入口 QQ邮箱网页版快速访问
邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧
React列表渲染与独立状态管理:避免全局状态影响局部更新
德邦快递查询平台 德邦快递物流信息查询入口
Fabric模组开发:自定义物品与物品组的现代管理方法
高德地图沿途添加点失败如何解决 高德多点规划方法
动漫岛观看全网网 动漫岛在线正版动漫入口
Steam官网入口直达 Steam注册及登录步骤
处理嵌套交互式控件:前端可访问性指南
AO3最新可访问网址 Archive of Our Own官方在线入口
C++如何实现一个装饰器模式_C++设计模式之动态地给对象添加额外职责
韩剧圈正版入口页面_韩剧圈官网登录链接
J*aScript教程:根据元素文本内容动态设置背景色
Composer的 archive 命令怎么用_快速打包你的PHP项目及其Composer依赖
火锅吃太多会怎样 火锅吃太多会上火吗
如何在 Excel Online 和 Google 表格中更改日期格式
海棠电脑版入口_通过电脑访问海棠官网阅读
俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问
Shopware订单对象中获取产品自定义字段的正确方法
在J*a里如何理解依赖关系的方向_依赖方向在模块结构中的作用
微信聊天记录怎么加密_微信聊天记录加密方法
在命令行怎么运行html项目_命令行运行html项目方法【教程】
苹果手机如何防止被恶意App追踪
在J*aScript中复现SciPy的B样条拟合与求值:关键考量
TypeScript/J*aScript:高效查找数组中首个唯一ID对象
mysql密码锁定怎么解锁_mysql密码锁定解锁后修改密码步骤
汽水音乐网页版使用入口_汽水音乐电脑版播放指南
深入理解字体排版:Adobe光学字偶距与CSS字偶距的差异与实现
谷歌google账号怎么注册账号 谷歌账号注册官方流程
php源码怎么看淘宝客系统_看php源码淘宝客系统技巧
哔哩哔哩忘记密码了怎么找回_哔哩哔哩密码找回方法
如何在更新Composer依赖后自动运行测试_使用post-update-cmd钩子触发PHPUnit
构建轻量级网站内部消息系统:Formspree 集成指南


2025-12-13
浏览次数:次
返回列表
Policy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>100MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender></p><p><!-- 根 logger:控制整体日志级别和输出目标 -->
<root level="INFO">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
</configuration>