Spring Boot动态修改logback框架日志级别

(1)原理

       日志框架中有一个工厂类:LoggerFactory,在这个类中可以获取到当前日志的上下文对象LoggerContext,通过LoggerContext可以获取到指定包的Logger ,通过Logger对象那就无所不能了。

(2)获取当前日志等级

代码:

@RequestMapping(value = "/getLoglevel")
 public Level getLoglevel( @RequestParam(value="package") String packageName) throws Exception {
        LoggerContext loggerContext = (LoggerContext)LoggerFactory.getILoggerFactory();
        return loggerContext.getLogger(packageName).getLevel();
 }

  

这里先获取到了LoggerContext,通过loggerContext,获取到了指定包的Logger对象,通过logger对象中的getLevel()方法获取到当前包的日志级别。

       访问地址:http://localhost:8080/getLoglevel?package=com.kfit可以看到控制台输出:

{"levelInt":20000,"levelStr":"INFO"}

(3)修改日志等级

       源码如下:

   @RequestMapping(value = "/loglevel/{loglevel}")
    public String loglevel(@PathVariable("loglevel") String logLevel, @RequestParam(value="package") String packageName) throws Exception {
        //trace --> debug --> info --> warn --> error -->fatal
        LoggerContext loggerContext =(LoggerContext)LoggerFactory.getILoggerFactory();
        loggerContext.getLogger(packageName).setLevel(Level.valueOf(logLevel));
        return "ok";
   }

 这里获取到LoggerContext之后,通过getLogger(packageName)获取到logger对象,通过logger对象的setLevel()方法,修改当前包的日志级别。

(4)更优的方案

       这种方案是通过我们自己编码的方法进行实现的,好消息是spring boot在1.5.+版本之后就实现了动态修改日志级别。具体可以看之前的文章《SpringBoot 动态修改日志级别》进行实现。

 

posted @ 2017-09-19 17:44  春雨如约而来  阅读(4128)  评论(3编辑  收藏  举报