springboot下 logback.xml配置

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-logging</artifactId>
</dependency>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <!--    日志的最大历史 30天-->

    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="rootPath" value="E:/logs"/>
    <property name="backupDir" value="backup"/>
    <property name="serverName" value="myTest"/>
    <!-- 控制台输出 -->
    <appender name="consoleAppender" class="ch.qos.logback.core.ConsoleAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{traceLogId}] [%thread] [%-5p] %logger{36} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <appender name="debugAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${rootPath}/${serverName}_debug.log</File>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <FileNamePattern>
                ${rootPath}/${backupDir}/${serverName}_debug-%d{yyyy-MM-dd}-%i.log.gz
            </FileNamePattern>
            <MaxHistory>7</MaxHistory>
            <MaxFileSize>100MB</MaxFileSize>
        </rollingPolicy>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{traceLogId}] [%thread] [%-5p] %logger{36} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${rootPath}/${serverName}_error.log</File>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <FileNamePattern>
                ${rootPath}/${backupDir}/${serverName}_error-%d{yyyy-MM-dd}-%i.log.gz
            </FileNamePattern>
            <MaxHistory>7</MaxHistory>
            <MaxFileSize>100MB</MaxFileSize>
        </rollingPolicy>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{traceLogId}] [%thread] [%-5p] %logger{36} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <appender name="sqlAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${rootPath}/${serverName}_sql.log</File>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <FileNamePattern>
                ${rootPath}/${backupDir}/${serverName}_sql-%d{yyyy-MM-dd}-%i.log.gz
            </FileNamePattern>
            <MaxHistory>7</MaxHistory>
            <MaxFileSize>100MB</MaxFileSize>
        </rollingPolicy>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{traceLogId}] [%thread] [%-5p] %logger{36} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
    <logger name="org.springframework" level="INFO"></logger>
    <logger name="org.mybatis" level="INFO"></logger>
    <logger name="org.apache.zookeeper" level="INFO"></logger>

    <!-- 日志输出级别 -->
    <root level="debug">
        <appender-ref ref="debugAppender"/>
        <appender-ref ref="errorAppender"/>
        <appender-ref ref="consoleAppender"/>
    </root>

    <!--会将sql执行语句输出到_sql.log文件
    <logger name="com.pan.demo.mapper" additivity="false">
        <level value="DEBUG"/>
        <appender-ref ref="sqlAppender"/>
    </logger>-->

    <!--生产环境:输出到文档-->

        <root level="info">
            <appender-ref ref="consoleAppender" />
            <appender-ref ref="debugAppender"/>
            <appender-ref ref="errorAppender"/>
        </root>


</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、付费专栏及课程。

余额充值