SpringBoot logback日志文件

本文详细介绍了如何在SpringBoot项目中根据不同环境配置日志等级,包括`logging.level`参数设置和自定义logback.xml文件的使用,以及如何在Maven项目中进行多环境配置。

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

SpringBoot 项目

根据不同环境,配置不同的日志等级
@logging.level@参数:SpringBoot 整合 maven 多环境配置
config自定义名称,普通项目无法使用,因为没读取yml文件

# 日志配置
logging:
  level:
    org.dromara: @logging.level@
    org.springframework: warn
    tech.powerjob.worker.background: warn
  config: classpath:logback-plus.xml

依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.30</version>
</dependency>

在这里插入图片描述

普通项目

在这里插入图片描述

普通项目必须要修改为logback.xml才会生效

在这里插入图片描述

示例

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
	<!-- property 代表定义一些变量可以供下面使用 -->
    <property name="log.path" value="./logs"/>
    <property name="console.log.pattern"
              value="%red(%d{yyyy-MM-dd HH:mm:ss}) %green([%thread]) %highlight(%-5level) %boldMagenta(%logger{36}%n) - %msg%n"/>
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"/>

    <!-- 控制台输出 -->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${console.log.pattern}</pattern>
            <charset>utf-8</charset>
        </encoder>
    </appender>

    <!-- 控制台输出 -->
    <appender name="file_console" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/sys-console.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
            <fileNamePattern>${log.path}/sys-console.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大 1-->
            <maxHistory>1</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
            <charset>utf-8</charset>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <!-- 过滤的级别 -->
            <level>INFO</level>
        </filter>
    </appender>

    <!-- 系统日志输出 -->
    <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/sys-info.log</file>
        <!-- 循环政策:基于时间创建日志文件 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
            <fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大的历史 60-->
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 过滤的级别 -->
            <level>INFO</level>
            <!-- 匹配时的操作:接收(记录) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配时的操作:拒绝(不记录) -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/sys-error.log</file>
        <!-- 循环政策:基于时间创建日志文件 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
            <fileNamePattern>${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大的历史 60-->
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 过滤的级别 -->
            <level>ERROR</level>
            <!-- 匹配时的操作:接收(记录) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配时的操作:拒绝(不记录) -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

	<!--异步日志记录是通过将日志记录操作与主应用程序线程解耦,以提升应用程序性能和响应速度的重要技术之一-->

    <!-- info异步输出 -->
    <appender name="async_info" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACTDEBUGINFO级别的日志 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="file_info"/>
    </appender>

    <!-- error异步输出 -->
    <appender name="async_error" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACTDEBUGINFO级别的日志 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender,最多只能添加一个 -->
        <appender-ref ref="file_error"/>
    </appender>


    <!--系统操作日志 如果没有明确指定日志附加器(appender),可能会有一些默认的附加器,比如输出到控制台或者默认的日志文件,指定异步的就不需要指定同步的了-->
    <root level="info">
        <appender-ref ref="console" />
        <appender-ref ref="async_info" />
        <appender-ref ref="async_error" />
        <appender-ref ref="file_console" />
    </root>

</configuration>

Appender的种类

  • ConsoleAppender(控制台附加器):将日志输出到控制台,通常是标准输出或标准错误输出。
  • FileAppender(文件附加器):将日志输出到指定的文件中。可以是普通的文件附加器,也可以是滚动文件附加器(例如,按时间或大小滚动)。
  • RollingFileAppender(滚动文件附加器):将日志输出到文件,并根据特定的策略(如时间或文件大小)滚动生成新的日志文件,以避免单个日志文件过大或保留历史日志。
  • AsyncAppender(异步附加器):将日志事件异步地传输到另一个appender,以提高日志记录的性能。通过内部队列和后台线程来实现异步输出。
  • SocketAppender(套接字附加器):将日志事件通过网络套接字发送到远程服务器或其他应用程序,用于集中管理和分析日志。
  • JDBCAppender(数据库附加器):将日志事件写入到关系型数据库(如MySQL、PostgreSQL)中,通常用于将日志数据集成到应用程序的数据存储中。
  • SMTPAppender(邮件附加器):将日志事件通过电子邮件发送给指定的收件人,用于重要的错误或警告通知。
  • NullAppender(空附加器):将所有的日志事件丢弃,即不做任何实际的日志记录操作,通常用于测试或调试阶段。这些appender类型覆盖了常见的日志输出场景,使得开发人员可以根据应用程序的需求选择合适的日志输出方式和目标。
### 关于 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、付费专栏及课程。

余额充值