spring boot3.3.5 logback-spring.xml 配置


新建 resources/logback-spring.xml 控制台输出颜色有点花 可以自己更改

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!--关闭文件扫描 scan=false -->
<configuration debug="false" scan="false">
    <springProperty scop="context" name="spring.application.name" source="spring.application.name"
                    defaultValue="atm-at-web"/>
    <!--    控制台颜色控制 %red(输出内容) 格式  %d{} 日期时间格式  %-5level日志级别   [%thread] 线程  %msg%n 日志内容 -->
    <!--    日志文件保存路径  项目/logs/子项目/info.log  项目/logs/子项目/warn.log -->
    <property name="log.path" value="logs/${spring.application.name}"/>
    <!-- 控制台输出样式 -->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%red(%d{MM-dd HH:mm:ss.SSS}) %highlight(%-5level) %green([%thread]) %yellow([%logger{50}]) - %cyan(%msg%n)
            </pattern>
        </encoder>
    </appender>

    <!-- info级别日志文件输出 -->
    <appender name="info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/info.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/%d{yyyy-MM}/info.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern>
            <maxFileSize>10MB</maxFileSize>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>%d{MM-dd HH:mm:ss.SSS} %-5level [%thread] [%logger{50}] - %msg%n</pattern>
        </encoder>
    </appender>

    <!-- 警告级别日志文件输出 -->
    <appender name="warn" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/warn.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/%d{yyyy-MM}/warn.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern>
            <maxFileSize>10MB</maxFileSize>
            <maxHistory>30</maxHistory>
            <totalSizeCap>3GB</totalSizeCap>
        </rollingPolicy>
        <encoder>
            <pattern>%d{MM-dd HH:mm:ss.SSS} %-5level [%thread] [%logger{50}] - %msg%n</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>warn</level>
        </filter>
    </appender>

    <root level="INFO">
        <appender-ref ref="console"/>
        <appender-ref ref="warn"/>
        <appender-ref ref="info"/>
    </root>

    <!--    指定某个类下某个函数的日志输出控制-->
    <turboFilter class="com.ys.filter.timing.TimingLogFilter"/>

    <!-- 屏蔽类sql输出 -->
    <!--    <logger name="com.ys.mapper.act.TaskPlMapper" level="info" additivity="false"/>-->
    <!--    <logger name="com.ys.mapper.act.PlMapper" level="info" additivity="false"/>-->
    <!--    <logger name="com.ys.mapper.act.ActMapper" level="info" additivity="false"/>-->
</configuration>
java 复制代码
package com.ys.filter.timing;

import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.turbo.TurboFilter;
import ch.qos.logback.core.spi.FilterReply;
import org.slf4j.Marker;

/**
 * @author kong
 */
public class TimingLogFilter extends TurboFilter {
    @Override
    public FilterReply decide(Marker marker, Logger logger, Level level, String s, Object[] objects, Throwable throwable) {
        if ("com.ys.mapper.act.TaskPlMapper.selectObjectListByQuery".equals(logger.getName())) {
        //不输出这个函数的日志
            return FilterReply.DENY;
        }
        return FilterReply.NEUTRAL;
    }
}
相关推荐
还是大剑师兰特1 小时前
Spring面试题及详细答案 125道(1-15) -- 核心概念与基础1
spring·大剑师·spring面试题·spring教程
python_1364 小时前
web请求和响应
java·spring·github
舒一笑4 小时前
Started TttttApplication in 0.257 seconds (没有 Web 依赖导致 JVM 正常退出)
jvm·spring boot·后端
ciku5 小时前
Spring AI Starter和文档解读
java·人工智能·spring
javadaydayup6 小时前
Apollo 凭什么能 “干掉” 本地配置?
spring boot·后端·spring
FFF-X6 小时前
Vue3 路由缓存实战:从基础到进阶的完整指南
vue.js·spring boot·缓存
耳东哇9 小时前
spring ai-openai-vl模型应用qwen-vl\gpt-文字识别-java
java·人工智能·spring
smileNicky19 小时前
SpringBoot系列之从繁琐配置到一键启动之旅
java·spring boot·后端
long31620 小时前
java 策略模式 demo
java·开发语言·后端·spring·设计模式
柏油21 小时前
Spring @Cacheable 解读
redis·后端·spring