SpringBoot Logback修改日志级别

  1. 在application.yml 通过配置配置,按住Ctrl + 左键可以看源码
javascript 复制代码
logging:
  level:
    root: info
    com.dj.test.controller: debug
    com.dj.test.service: debug
  1. 自己写接口直接动态修改日志级别,读取application.yml配置文件算是间接修改
java 复制代码
package com.dj.springtest.controller;

import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Arrays;
import java.util.List;

/**
 * Date: 2024/1/13
 * Time: 22:02
 * Description: No Description
 */
@RestController
public class LogController {

    private static final List<String> LEVELS = Arrays.asList("ALL", "all", "TRACE", "trace", "DEBUG", "debug", "INFO", "info", "WARN", "warn", "ERROR", "error", "OFF", "off");

    /**
     * 设置日志界级别
     *
     * @param overall     全局设置
     * @param part        部分设置
     * @param packagePath 涵盖包,如果有多个path,请使用英文逗号分隔
     */
    @GetMapping("/log/level")
    public String setLogLevel(String overall, String part, String packagePath) {
        LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory();
        if (StringUtils.isNotBlank(overall) && LEVELS.contains(overall)) {
            Logger rootLogger = loggerContext.getLogger("root");
            rootLogger.setLevel(Level.toLevel(overall));
        }

        //根据包路径进行设置
        if (StringUtils.isNotBlank(part) && LEVELS.contains(part) && StringUtils.isNotBlank(packagePath)) {
            String[] paths = packagePath.split(",");
            for (String path : paths) {
                Logger pathLogger = loggerContext.getLogger(path);
                pathLogger.setLevel(Level.toLevel(part));
            }
        }

        return "Succeeded in changing the log level";
    }

}
相关推荐
栈与堆37 分钟前
LeetCode 19 - 删除链表的倒数第N个节点
java·开发语言·数据结构·python·算法·leetcode·链表
一路向北·重庆分伦39 分钟前
03-01:MQ常见问题梳理
java·开发语言
一 乐40 分钟前
绿色农产品销售|基于springboot + vue绿色农产品销售系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·宠物
lhrimperial1 小时前
企业智能知识库助手落地实践:从RAG到Multi-Agent
java·spring cloud·微服务·系统架构·知识图谱
3***68841 小时前
Spring Boot中使用Server-Sent Events (SSE) 实现实时数据推送教程
java·spring boot·后端
C***u1761 小时前
Spring Boot问题总结
java·spring boot·后端
Elieal1 小时前
5 种方式快速创建 SpringBoot 项目
java·spring boot·后端
better_liang1 小时前
每日Java面试场景题知识点之-Java修饰符
java·访问控制·static·abstract·final·修饰符·企业级开发
rgeshfgreh2 小时前
Spring事务传播机制深度解析
java·前端·数据库
无名-CODING2 小时前
Java Spring 事务管理深度指南
java·数据库·spring