(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 动态修改日志级别》进行实现。

 

相关文章:

  • 2021-10-28
  • 2022-12-23
  • 2021-08-03
  • 2021-12-11
  • 2021-11-30
  • 2022-12-23
  • 2022-02-20
  • 2021-11-16
猜你喜欢
  • 2021-11-25
  • 2021-05-27
  • 2021-07-13
  • 2022-12-23
  • 2021-06-02
  • 2021-08-24
  • 2022-12-23
相关资源
相似解决方案