Spring Boot 1.5.x新特性:动态修改日志级别

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"}

即该类没有配置自己的日志级别,而是采用其所在包的日志级别。

 

 

参考资料:

https://blog.csdn.net/dyc87112/article/details/54866244

http://www.cnblogs.com/heqiyoujing/p/9470752.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值