Java中logback 自动刷新不生效的问题解决
一、背景
今天心血来潮,准备测试一下项目中 logback 的自动刷新功能,但是测试时发现并不生效。logback 的配置如下:
<configuration scan="true" scanPeriod="10 seconds">
可以看到,配置了 10s 的自动刷新
二、问题排查
排查这种问题最好的方法,看日志。所以我们需要先开启 logback 自身运行时的日志,在配置项中增加一个 debug
配置,开启方法如下:
<configuration scan="true" scanPeriod="10 seconds" debug="true">
启动项目,发现输出了如下日志:
此异常日志不影响项目最终启动成功。重点在这句话:
Failed to rename context [logback] as [nacos] java.lang.IllegalStateException: Context has been already given a name
通过日志猜测,是 nacos 自带的 logback 影响了 springboot 服务中配置的 logback,导致自动刷新不生效
三、问题处理
我们选择禁用掉 nacos 的 logback,在 nacos 官网找了一圈后,发现可以通过以下参数禁用 nacos.logging.default.config.enabled
,推荐两种配置方式:
- 在启动参数中添加:
-Dnacos.logging.default.config.enabled=false
- 在 springboot 的启动类中,增加如下配置:
public static void main(String[] args) { // 禁用 nacos 的默认日志 System.setProperty("nacos.logging.default.config.enabled", "false"); SpringApplication.run(OrderApplication.class, args); }
以上两种方法均可。添加完成后,scanPeriod
的自动刷新就生效了。
另外说一个小坑,如果是在本地的 idea 中测试 logback 的自动刷新,记得在修改了 logback
的配置后,需要对文件进行重新编译(或者直接修改 target 下 classes 中的 logback
文件)
到此这篇关于Java中logback 自动刷新不生效的问题解决的文章就介绍到这了,更多相关Java logback 自动刷新不生效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
java基于servlet使用组件smartUpload实现文件上传
这篇文章主要介绍了java基于servlet使用组件smartUpload实现文件上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-10-10spring-boot-starter-validation 校验参数的实现
参数校验在很多地方都可以用到,本文主要介绍了spring-boot-starter-validation 校验参数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-04-04Java的线程池ThreadPoolExecutor及多种线程池实现详解
这篇文章主要介绍了Java的线程池ThreadPoolExecutor及多种线程池实现详解,ThreadPoolExecutor 使用 int 的高 3 位来表示线程池状态,低 29 位表示线程数量,之所以将信息存储在一个变量中,是为了保证原子性,需要的朋友可以参考下2024-01-01
最新评论