Springboot动态修改日志级别

在开发和运维过程中,我们经常需要调整日志级别来查看不同级别的日志信息。传统的做法是修改配置文件,然后重启应用程序。但是,在分布式系统中,重启应用程序可能比较麻烦,而且也影响了业务的正常运行。

Springboot提供了动态修改日志级别的功能,可以通过HTTP请求来修改日志级别,无需重启应用程序。

实现原理

Springboot动态修改日志级别通过LoggingSystem接口实现。LoggingSystem是一个抽象类,提供了setLogLevel()方法来修改日志级别。

我们可以通过@Resource注解注入LoggingSystem对象,然后调用setLogLevel()方法来修改日志级别。

示例代码

java 复制代码
@RestController
@RequestMapping("log")
@Api(tags = "日志")
@RequiredArgsConstructor
public class LogSystemController {
    private final LoggingSystem loggingSystem;

    @GetMapping("/change")
    @ApiOperation(value = "动态修改日志级别")
    @SaCheckRole(value = "system:admin:admin")
    public R<?> mobile(@RequestParam String loggerName, @RequestParam LogLevel level) {
        loggingSystem.setLogLevel(loggerName, level);
        return R.ok();
    }

}

这个示例代码定义了一个LogSystemController控制器,其中包含一个change()方法。change()方法接收两个参数:loggerName和level。loggerName表示要修改的日志名称,level表示新的日志级别。

change()方法通过LoggingSystem对象的setLogLevel()方法来修改日志级别。

测试

启动Springboot应用程序,然后访问http://localhost:8080/log/change?loggerName=com.example.demo\&level=DEBUG。

修改日志级别后,可以看到com.example.demo包下的所有日志都被打印成了DEBUG级别。

总结

Springboot动态修改日志级别功能可以方便我们在开发和运维过程中调整日志级别,无需重启应用程序。

相关推荐
Irene19912 天前
(课堂笔记)PL/SQL:异常处理、数据同步、日志
oracle·异常处理·日志·数据同步
哆啦A梦15882 天前
01, 前端vue3框架的快速搭建以及项目工程的讲解
前端·vue3·springboot
桃花键神3 天前
【2026精品项目】基于SpringBoot3+Vue3的校园小卖铺系统(包含源码+项目文档+SQL脚本+部署教程)
数据库·sql·vue·毕业设计·springboot
洛阳泰山4 天前
Maxkb4j集成sqlbot MCP实现企业智能问数智能体
java·ai·springboot·agent·智能问数
庞轩px4 天前
第六篇:Redo Log与Binlog——崩溃恢复的底层保障
mysql·binlog·数据安全·innodb·日志·redo log·update
zc.z4 天前
基于 LangChain4j 的 RAG 工作流智能体实战
langchain·大模型·springboot·rag智能体
七夜zippoe4 天前
OpenClaw 日志记忆:memory/YYYY-MM-DD.md
memory·日志·记录·记忆·openclaw
沪漂阿龙5 天前
大模型全链路追踪怎么做?从用户提问到模型回答,一次请求到底经历了什么
人工智能·日志
suweijie7685 天前
Nacos配置读取异常排查与解决指南
微服务·nacos·springboot·配置中心·问题排查
程序员老邢5 天前
【产品底稿 12】工程架构最终定型:完整模块拆分、分包规范、层级依赖与开发规约全清单
微服务·架构·springboot·多模块·技术债务