SpringBoot日志管理 —— 解决Logback生成 "LOG_PATH_IS_UNDEFINED" 文件夹问题

问题背景

在我们的SpringBoot 2.4项目中,我们使用Logback作为我们的日志框架。我们注意到在项目的根路径下面出现了一个名为 LOG_PATH_IS_UNDEFINED 的文件夹,我们所有的日志文件都在这个文件夹中。定义的日志文件并没有在指定的路径中生成。

原因分析

经过分析推测是 logback 配置文件存在问题,因为日志的输出格式是正确的,生成的文件也是正确,文件存放路径是错误的,应该是路径配置出现了问题,这里有一个代码片段:

xml 复制代码
<appender class="ch.qos.logback.core.rolling.RollingFileAppender" name="TRACE_FILE">
    <file>${LOG_PATH}/trace.log</file>
    ...
  </appender>
  ...
  <property name="LOG_PATH" value="./logs"/>

在这段代码中,LOG_PATH是我们定义的一个变量,它被用来指定我们日志文件的路径。但是问题在于,我们在使用这个变量的地方(file元素的LOG_PATH)之前,我们就需要它的值,这导致在logback尝试解析${LOG_PATH}的时候,它并没有找到对应的值,于是作为默认值,logback就使用了LOG_PATH_IS_UNDEFINED

解决方法

解决这个问题的方法是需要保证我们在使用LOG_PATH变量之前定义它。我们可以将定义LOG_PATH的那行代码移动到<configuration>标签的开头:

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <property name="LOG_PATH" value="./logs"/>
  ...
</configuration>

要避免这种问题的发生,需要确保在使用任何变量之前都已经定义了它。特别是在配置文件中,我们需要明确知道配置文件的解析顺序,也就是说,当使用某个配置属性时,必须确保它已经在之前的位置被定义。如果在使用的地方之前没有定义,将会导致未定义的默认值(如本例中的 "LOG_PATH_IS_UNDEFINED")被使用。

相关推荐
计算机毕设匠心工作室28 分钟前
【python大数据毕设实战】全面皮肤病症状数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql
毕设源码-郭学长35 分钟前
【开题答辩全过程】以 高校教材大管家系统为例,包含答辩的问题和答案
java·spring boot
摆烂工程师35 分钟前
2025年12月最新的 Google AI One Pro 1年会员教育认证通关指南
前端·后端·ai编程
qq_12498707531 小时前
基于SpringBoot+vue的小黄蜂外卖平台(源码+论文+部署+安装)
java·开发语言·vue.js·spring boot·后端·mysql·毕业设计
i02081 小时前
Java 17 + Spring Boot 3.2.5 使用 Redis 实现“生产者–消费者”任务队列
java·spring boot·redis
代码与野兽1 小时前
AI交易,怎么让LLM自己挑选数据源?
前端·javascript·后端
天天摸鱼的java工程师2 小时前
JDK 25 到底更新了什么?这篇全景式解读带你全面掌握
java·后端
非鱼feiyu2 小时前
自关联数据表查询优化实践:以 Django + 递归 CTE 构建树结构为例
数据库·后端·django
5***b972 小时前
SpringBoot(整合MyBatis + MyBatis-Plus + MyBatisX插件使用)
spring boot·tomcat·mybatis
零日失眠者2 小时前
这5个Python库一旦掌握就离不开
后端·python