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

作者:常金家的秋意 时间:2022-09-07 21:26:04 

一、背景

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

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

可以看到,配置了 10s 的自动刷新

二、问题排查

排查这种问题最好的方法,看日志。所以我们需要先开启 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 服务中配置的 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 文件)

来源:https://juejin.cn/post/7229667871604899897

标签:Java,logback,自动刷新
0
投稿

猜你喜欢

  • 浅谈byte和长度为8的boolean数组互相转换

    2023-11-07 00:34:37
  • opencv 做人脸识别 opencv 人脸匹配分析

    2023-07-09 06:34:44
  • 通过Docker启动Solace并在Spring Boot通过JMS整合Solace的操作方法

    2023-07-11 09:52:28
  • spring如何动态指定具体实现类

    2022-04-13 07:52:21
  • Kotlin开发笔记之委托属性与区间(译)

    2022-07-12 19:14:32
  • 关于C#委托三种调用的分享使用

    2022-10-29 03:24:35
  • 为Android应用增加渠道信息 自动化不同渠道的打包过程的使用详解

    2022-06-01 11:38:22
  • c#解压文件的实例方法

    2022-04-25 09:49:40
  • SpringBoot中@ConfigurationProperties注解实现配置绑定的三种方法

    2023-03-19 12:36:25
  • Java用递归方法解决汉诺塔问题详解

    2022-11-23 03:11:40
  • Java类中this关键字与static关键字的用法解析

    2023-11-09 22:45:19
  • 一次排查@CacheEvict注解失效的经历及解决

    2023-11-13 12:07:23
  • 如何使用Java给您的图片瘦身之Thumbnailator技术

    2023-10-31 10:25:52
  • Android 仿今日头条评论时键盘自动弹出的效果(推荐)

    2022-07-24 15:00:45
  • Java并发包之CopyOnWriteArrayList类的深入讲解

    2022-10-06 09:15:21
  • 详解WPF中的APP生命周期以及全局异常捕获

    2022-12-10 11:54:27
  • Android iOS常用APP崩溃日志获取命令方法

    2022-06-15 08:07:14
  • JAVA利用HttpClient进行HTTPS接口调用的方法

    2023-10-24 16:28:11
  • java程序员必须要学会的linux命令总结(推荐)

    2021-12-11 00:47:47
  • C# 中闭包(Closure)详解

    2022-12-29 20:36:10
  • asp之家 软件编程 m.aspxhome.com