Spring Boot配置 Logback 实现Info ,Error日志分别记录到文件

1. 关于 Logback

logback是spring boot的默认集成好的日志框架,因此我们不需要引入依赖, 直接在 resources 文件下面直接建立 日志配置文件 logback- spring.xml

目录结构如图

2. 具体配置代码

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 定义日志保存的路径变量,logs是spring boot 配置文件中配置的保存路径 -->
    <springProperty scope="context" name="LOG_HOME" source="logs"/>
    <property name="INFO_PATH" value="info" />
    <property name="ERROR_PATH" value="error" />
    <property name="ACCESS_LOG_PATH" value="access" />

    <!-- 定义一个控制台输出器,名为console-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--配置日志输出的格式-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%black(console--) %red(%d{yyyy-MM-dd HH:mm:ss}) %green([%thread]) %highlight(%-5level) %boldMagenta(%logger{10}) - %cyan(%msg%n)</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!--定义info级别的输出器-->
    <appender name="info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss} %-5level [%thread]  %logger{30} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <!-- 定义保存的日志文件名格式 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_HOME}/${INFO_PATH}/info_%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
    </appender>

    <!--定义error级别的输出器-->
    <appender name="error" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss} %-5level [%thread]  %logger{30} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--保存路径-->
            <fileNamePattern>${LOG_HOME}/${ERROR_PATH}/error_%d{yyyy-MM-dd}.log</fileNamePattern>
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
    </appender>
  
    <!-- 定义日志全局最低输出级别是INFO,同时向控制台和日滚动文件输出 -->
    <root level="INFO">
        <!--负责控制台输出-->
        <appender-ref ref="console" />
        <!--负责文件输出-->
        <appender-ref ref="info" />
        <appender-ref ref="error" />
    </root>
</configuration>

3. 补充一些配置信息

springboot配置文件中配置 windows 日志保存存储路径, 部署时切换成linux路径
spring boot配置文件信息

日志文件windows保存路径:
windows日志保存路径

配置参考

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值