springboot1.5.6版本运行时动态切换日志级别

springboot1.5之前的版本好像没有这个特性需要自己实现一个actuator endpoint,1.5之后的actuator新增了endpoint支持查看日志文件,查看日志级别和动态改变日志级别.

默认使用的是logback作为日志框架,需要引入:

<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-actuator</artifactId>
		</dependency>

测试目的,可以把权限问题关闭,不然访问endpoint的时候会报401错误,在application.yml中配置:

management:
  context-path: /admin
  security:
    enabled: false

然后启动应用程序,在浏览器里面输入http://localhost:8080/admin/loggers就可以看到所有的loggers和相应的日志级别信息,也可以输入指定的logger name查看指定的logger信息:

http://localhost:9090/admin/loggers/com.example.webdemo.controller

此时显示:

{
    "configuredLevel": "DEBUG",
    "effectiveLevel": "DEBUG"
}

比如我要改变com.example.webdemo.controller的日志级别,可以发送一个post请求:

curl -i -X POST -H 'Content-Type: application/json' -d '{"configuredLevel": "WARN"}' http://localhost:8080/loggers/com.example.webdemo.controller
再在浏览器里面查看一下http://localhost:9090/admin/loggers/com.example.webdemo.controller

此时日志级别已经改变:

{
    "configuredLevel": "WARN",
    "effectiveLevel": "WARN"
}

这样调试日志变得跟方便了,再做一个web页面来管理这些logger配置使用起来更方便

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值