springboot按照日期将日志打印到文件中

本文介绍了如何在Spring Boot项目中配置logback-spring.xml,以实现日志的控制台输出和文件滚动存储。配置包括彩色控制台输出、按日期生成日志文件、不同包的日志级别设置,以及日志过滤等功能。通过设置多个appender,实现了日志管理的灵活性。

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

在\src\main\resources路径下添加logback-spring.xml文件,文件内容如下,根据需求可以配置多个appender。(前提已经在maven中添加了logback,log4j的包)

<?xml version="1.0" encoding="UTF-8"?>
<!--
        1控制台输出日志,同时将日志保存到文件里;
        2保持控制台日志的彩色;
        3按月建日志文件夹,按天建日志文件;
        4com.lpc包下的日志从TRACE级别开始输出,其他包(比如tomcat的日志,SpringSecurity的日志)从INFO级别开始输出。
        跟原来yml里面配置logging.level.com.lpc: trace的输出结果保持一致。-->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <contextName>logback</contextName>

    <!--控制台输出内容的颜色转换以及格式-->
    <substitutionProperty name="logging.pattern.console"
                          value="%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>
    <!--日志文件输出内容的格式-->
    <substitutionProperty name="logging.pattern.file"
                          value="%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>

    <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter"/>
    <conversionRule conversionWord="wex"
                    converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"/>
    <conversionRule conversionWord="wEx"
                    converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"/>

    <!--输出到控制台-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--控制台使用layout节点-->
        <layout class="ch.qos.logback.classic.PatternLayout">
            <pattern>
                ${logging.pattern.console}
            </pattern>
        </layout>
    </appender>

    <!--按天生成日志-->
    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Prudent>true</Prudent>
        <!--滚动策略,我配置了按天生成日志文件-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--相对路径,生成的文件就在项目根目录下-->
            <FileNamePattern>
                logs/%d{yyyy-MM}/%d{yyyy-MM-dd}.log
            </FileNamePattern>
            <!--注意超过365天的日志文件会被删除,即使已经按天分开也会删除-->
            <MaxHistory>365</MaxHistory>
        </rollingPolicy>
        <!--日志文件里只保存ERROR及以上级别的日志-->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<!--
            <level>ERROR</level>
-->
        </filter>
        <!--文件使用encoder节点-->
        <encoder>
            <Pattern>
                ${logging.pattern.file}
            </Pattern>
        </encoder>
    </appender>


    <!--这个logger里的配置相当于之前yml里的logging.level.com.lpc: trace-->
    <!--additivity的作用-->
    <!--true,则子Logger不止会在自己的appender里输出,还会在root的logger的appender里输出-->
    <!--而这个logger里没配置appender,所以得交给root打印-->
    <!--所以com.lpc包里的日志从TRACE级别开始-->
    <!--其他包里的日志根据root的配置从INFO级别开始打印-->
    <logger name="com.lpc" level="TRACE" additivity="true">
    </logger>

    <root level="INFO">
        <appender-ref ref="console"/>
        <!--输出日志到文件-->
        <appender-ref ref="file"/>

    </root>

</configuration>


### Spring Boot 配置 Logback 日志输出到本地文件Spring Boot 应用程序中,Logback 是默认的日志实现工具。为了将日志输出到本地文件,可以通过配置 `logback-spring.xml` 或者其他自定义的 Logback 配置文件来完成这一目标。 #### 1. 添加依赖 Spring Boot 默认集成了 Logback,因此通常情况下不需要额外引入 Logback 的依赖项。但如果需要显式声明,则可以在项目的 `pom.xml` 文件中添加以下内容: ```xml <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> </dependency> ``` 此部分操作仅适用于未启用默认 Logback 实现的情况[^4]。 --- #### 2. 创建 Logback 配置文件 创建一个名为 `logback-spring.xml` 的文件,并将其放置于类路径下的资源目录 (`src/main/resources`) 中。以下是该文件的一个典型示例: ```xml <?xml version="1.0" encoding="UTF-8"?> <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.rolling.RollingFileAppender"> <file>${LOG_PATH}/application.log</file> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 每天生成一个新的日志文件 --> <fileNamePattern>${LOG_PATH}/application-%d{yyyy-MM-dd}.log</fileNamePattern> <!-- 保留最近7天的日志文件 --> <maxHistory>7</maxHistory> </rollingPolicy> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <!-- 设置全局日志级别 --> <root level="info"> <appender-ref ref="CONSOLE"/> <appender-ref ref="FILE"/> </root> </configuration> ``` 上述配置说明如下: - 使用 `${LOG_PATH}` 变量指定了日志文件的存储路径。 - `ConsoleAppender` 负责向控制台输出日志。 - `RollingFileAppender` 将日志写入文件,并按日期滚动生成新的日志文件。 - `<maxHistory>` 参数用于限制历史日志文件的数量,防止磁盘空间被过度占用[^2]。 --- #### 3. 修改 application.properties 或 application.yml 为了让 Spring Boot 加载自定义的 Logback 配置文件,需在 `application.properties` 或 `application.yml` 中指定配置文件的位置: ##### **application.properties** ```properties logging.config=classpath:logback-spring.xml ``` ##### **application.yml** ```yaml logging: config: classpath:logback-spring.xml ``` 此外,还可以通过 `logging.level` 来调整特定包的日志级别。例如: ```properties logging.level.com.example=DEBUG ``` 这会将 `com.example` 包及其子包中的日志级别设置为 DEBUG[^3]。 --- #### 4. 测试日志输出 编写一段简单的代码验证日志是否正常输出至本地文件: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DemoApplication { private static final Logger logger = LoggerFactory.getLogger(DemoApplication.class); public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); // 记录不同级别的日志 logger.info("This is an info message."); logger.debug("This is a debug message."); logger.error("This is an error message."); } } ``` 运行应用程序后,检查指定路径下的日志文件(如 `./logs/application.log`),确认日志已成功写入其中[^5]。 --- ### 注意事项 - 如果希望利用 Spring Boot 的高级特性(如环境变量注入等),应优先使用 `logback-spring.xml` 而不是普通的 `logback.xml`。 - 在生产环境中,务必合理配置日志文件大小、轮转策略以及最大保留时间,以免造成磁盘空间不足的问题。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值