springboot Logback 不同环境,配置不同的日志输出路径

文章讲述了在Mac笔记本开发环境中,如何通过修改logback-spring.xml文件来实现本地开发时日志写入当前项目data/logs目录,而在其他环境中写入系统根目录。涉及到SpringProfile和logback配置的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.背景:

mac 笔记本开发,日志文件写到/data/logs/下,控制台报出:Failed to create parent directories for [/data/logs/...........

再去手动在命令窗口创建文件夹data,报Read-only file system

2.修改logback-spring.xml文件:

resource 目录下的配置文件列表:

在logback-spring.xml添加配置, 只有local写到当前项目下的data目录,其他环境写到系统根目录/data下

<springProfile name="local">
    <property name="LOG_HOME" value="./data/logs/${appName}/${hostname}/"/>
</springProfile>

完整的logback-spring.xm

<?xml version="1.0" encoding="UTF-8"?>

<configuration debug="false">
    <include resource="org/springframework/boot/logging/logback/defaults.xml"/>
    <springProperty scope="context" name="appName" source="spring.application.name"
                    defaultValue="onemap-quality-manage-service"/>
    <springProperty scope="context" name="ip" source="spring.cloud.client.ip-address"/>
    <property name="CONSOLE_LOG_PATTERN"
              value="[%d{yyyy-MM-dd HH:mm:ss.SSS}] [${ip} ${appName}] [%(%-5level) %logger{80}:%line]:%msg%n"/>
    <property name="LOG_HOME" value="/data/logs/${appName}/${hostname}/"/>
    <springProfile name="local">
        <property name="LOG_HOME" value="./data/logs/${appName}/${hostname}/"/>
    </springProfile>
    <!-- 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>${CONSOLE_LOG_PATTERN}</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!-- 日志文件:按照每天生成 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_HOME}/${appName}-${ip}-info.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件地址和名称-->
            <FileNamePattern>${LOG_HOME}/${appName}-${ip}-info-%d{yyyy-MM-dd}.log</FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>${CONSOLE_LOG_PATTERN}</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!-- error日志 -->
    <appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_HOME}/${appName}-${ip}-error.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件地址和名称-->
            <FileNamePattern>${LOG_HOME}/${appName}-${ip}-error-%d{yyyy-MM-dd}.log</FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>${CONSOLE_LOG_PATTERN}</pattern>
            <charset>UTF-8</charset>
        </encoder>

        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level><!-- 只接收错误级别的日志 -->
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!--设置框架的日志-->
    <logger name="org.springframework" level="INFO"/>
    <logger name="org.apache" level="WARN"/>

    <!-- 日志输出级别 -->
    <root level="INFO">
        <appender-ref ref="STDOUT"/>
        <appender-ref ref="FILE"/>
        <appender-ref ref="ERROR"/>
    </root>
</configuration>

3.profiles.active 指定配置的local

日志写到当前项目下的/data/目录

### 关于 Spring Boot 中 `logback.xml` 配置文件 在 Spring Boot 项目中,可以通过配置 `logback.xml` 来定制化日志记录行为。此文件提供了对日志输出格式、日志级别以及日志目的地的高度灵活性[^2]。 #### 日志配置基本结构 以下是 `logback.xml` 文件的一个基础模板: ```xml <configuration> <!-- 定义全局属性 --> <property name="LOG_PATH" value="./logs"/> <!-- 控制台日志输出设置 --> <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <!-- 文件日志输出设置 --> <appender name="FILE" class="ch.qos.logback.core.FileAppender"> <file>${LOG_PATH}/application.log</file> <append>true</append> <encoder> <pattern>%date %level [%thread] %logger{10} [%file:%line] %msg%n</pattern> </encoder> </appender> <!-- 设置根日志级别并指定使用的 appender --> <root level="info"> <appender-ref ref="CONSOLE" /> <appender-ref ref="FILE" /> </root> </configuration> ``` 上述 XML 结构展示了如何创建一个简单的日志配置方案,其中包含了两个主要部:一个是用于终端显示的日志信息;另一个则是保存到本地磁盘上的日志条目。此外还设置了默认的日志等级为 info,并指定了这两个 appenders 应该被应用于整个应用程序的日志处理过程之中。 值得注意的是,在某些情况下可能希望利用 Spring Boot 自身的优势来增强日志系统的功能性。这时可以选择使用 `logback-spring.xml` 而不是普通的 `logback.xml` 文件。前者能够更好地与 Spring 生态系统相结合,提供诸如环境变量替换等功能的支持[^1]。 例如,如果想要让日志路径根据不同的运行环境而变化,则可以在 `application.properties` 或者 `application.yml` 文件里定义相应的 key-value 对(如 `logging.path=/var/log/myapp/`),之后再通过 `${}` 表达式语法将其引入至 `logback-spring.xml` 当中去实现动态调整的目的[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值