Spring Boot 1.5.x中引入的一个新的控制端点:/loggers,该端点将为我们提供动态修改Spring Boot应用日志级别的强大功能。该功能的使用非常简单,它依然延续了Spring Boot自动化配置的实现,所以只需要在引入了spring-boot-starter-actuator依赖的条件下就会自动开启该端点的功能。但是,如果要访问该端点,需要关闭安全认证校验,在配置文件中加入如下配置:
management.security.enabled=false
可以在controller写一个方法来测试动态日志级别
@RequestMapping(value="/testLog",method=RequestMethod.GET)
public void testLog() {
logger.debug("debug msg");
logger.info("info msg");
logger.warn("warn msg");
logger.error("error msg");
}
假设我们配置默认的日志级别是info,当我们调这个测试方法的时候,可以看到输出info msg、warn msg和error msg。
访问loggers端点如:http://localhost:1001/loggers
可以看到所有包及类的日志级别,如:
"levels":["OFF","ERROR","WARN","INFO","DEBUG","TRACE"],"loggers":{"ROOT":{"configuredLevel":"INFO","effectiveLevel":"INFO"},"com":{"configuredLevel":null,"effectiveLevel":"INFO"},"com.netflix":{"configuredLevel":null,"effectiveLevel":"INFO"},"com.netflix.appinfo":{"configuredLevel":null,"effectiveLevel":"INFO"},"com.netflix.appinfo.ApplicationInfoManager":{"configuredLevel":null,"effectiveLevel":"INFO"}......."com.userInfoService.controller":{"configuredLevel":null,"effectiveLevel":"INFO"},"com.userInfoService.controller.UserInfoController":{"configuredLevel":null,"effectiveLevel":"INFO"}......
configuredLevel代表当前包或类的配置级别,effectiveLevel代表当前包或类的生效级别,如果某个类没有配级别,则该类的configuredLevel为null,如果该类所在的包的级别时INFO,则该类的effectiveLevel也为INFO,上面的结果可以看到,只有ROOT设置了configuredLevel为INFO,它下面所有的包及类都没有设置,所以其它的configuredLevel都时null,此时ROOT下的所有包及类都采用ROOT的级别,即effectiveLevel为INFO。
假设前面的测试代码在UserInfoController类中,现在,我们发送POST请求到http://localhost:1001/loggers/com.userInfoService.controller.UserInfoController端点,其中请求体Body内容为:
{ "configuredLevel": "DEBUG" }
此时再访问loggers端点,可以看到日志该类的日志级别变成debug了
"com.userInfoService.controller.UserInfoController":{"configuredLevel":"DEBUG","effectiveLevel":"DEBUG"}
我们再调用该测试方法时,可以看到debug msg也被打印出来了。
我们也可以通过改变包的日志级别来影响该包下所有的类的日志级别,但如果你设置了该包里某个类的日志级别,则以类的设置优先,假如已经设置类某个类的日志级别,但又想通过包来设置该类,此时应该先把类的日志级别清空,还是通过之前的post请求,但是请求报文为{},代表置空,此时可以看到
"com.userInfoService.controller.UserInfoController":{"configuredLevel":null,"effectiveLevel":"INFO"}
这时我们可以对包设置日志级别,发送post请求到http://localhost:1001/loggers/com.userInfoService.controller
报文内容为:
{
"configuredLevel":"DEBUG"
}此时可以看到该包下的类的日志级别如下:
"com.userInfoService.controller.UserInfoController":{"configuredLevel":null,"effectiveLevel":"DEBUG"}
即该类没有配置自己的日志级别,而是采用其所在包的日志级别。