开发者

Java中logback 自动刷新不生效的问题解决

开发者 https://www.devze.com 2023-05-08 10:37 出处:网络 作者: 常金家的秋意
目录一、背景二、问题排查三、问题处理一、背景 今天心血来潮,准备测试一下项目中 logback 的自动刷新功能,但是测试时发现并不生效。logback 的配置如下:
目录
  • 一、背景
  • 二、问题排查
  • 三、问题处理

一、背景

今天心血来潮,准备测试一下项目中 logback 的自动刷新功能,但是测试时发现并不生效。logback 的配置如下:

<configuration scan="androidtrue" scanPeriod="10 seconds">

可以看到,配置了 10s 的自动编程客栈刷新

二、问题排查

排查这种python问题最好的方法,看日志。所以我们需要先开启 logback 自身运行时的日志,在配置项中增加一个 debug 配置,开启方法如下:

<configuration scan="true" scanPeriod="10 seconds" debug="true">

启动项目,发现输出了如下日志:

Java中logback 自动刷新不生效的问题解决

此异常日志不影响项目最终启动成功。重点在这句话:

Failed to rename context [logback]编程客栈 as [nacos] Java.lang.IllegalStateException: Context has been already given a name

通过日志猜测,是 nacos 自带的 logback 影响了 springboot 服www.devze.com务中配置的 开发者_开发学习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 自动刷新不生效内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

0

精彩评论

暂无评论...
验证码 换一张
取 消