springboot logback日志文件生产配置

本文详细解析了Logback的日志配置文件logback-spring.xml,涵盖了不同类型的日志输出,如ELK日志、普通日志及错误日志的格式设定,滚动策略和历史记录的管理。

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

logback-spring.xml模版

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <include resource="org/springframework/boot/logging/logback/defaults.xml"/>
    <property name="LOG_FILE" value="/home/www/log/company-song-api"/>
    <include resource="org/springframework/boot/logging/logback/console-appender.xml"/>

    <!-- ELK日志 -->
    <appender name="ELK" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_FILE}/%d{yyyy-MM-dd}.%i.log
            </fileNamePattern>
            <maxHistory>14</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <pattern>%m%n</pattern>
        </encoder>
    </appender>

    <!--普通日志格式-->
    <appender name="F" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>logs/info.%d{yyyy-MM-dd}.%i.log
            </fileNamePattern>
            <maxHistory>30</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
        </encoder>
    </appender>

    <!-- 错误日志 -->
    <appender name="E" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>logs/error.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <maxHistory>365</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
    </appender>

    <root level="INFO">
        <appender-ref ref="F"/>
        <appender-ref ref="E"/>
        <appender-ref ref="CONSOLE"/>
    </root>

    <logger name="com.aop.WebLogAspect" level="INFO" additivity="false">
        <appender-ref ref="ELK"/>
        <appender-ref ref="E"/>
        <appender-ref ref="CONSOLE"/>
    </logger>
</configuration>
### 关于 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、付费专栏及课程。

余额充值