nacos配置中心动态刷新数据源成功经验 | 大别山码将

本文主要是介绍nacos配置中心动态刷新数据源成功经验 | 大别山码将,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

nacos配置中心动态刷新数据源成功经验

现在的项目需求是使用配置中心统一管理所有的项目配置(开发,配置,生产)
在配置中心修改相应参量数值的时候,本地的配置文件数据也能动态的更新

这是我本地的yaml文件配置:
在这里插入图片描述
这是本地nacos控制台配置:
在这里插入图片描述

这是测试部分代码:
在这里插入图片描述
现在启动项目访问测试地址:访问到预期数据20
在这里插入图片描述
实现在nacos修改配置就能同步到本地配置文件的话
需要在整个类或者参数所在的方法上加@RefreshScope注解
经测试在整个类上加@RefershScpoe可行,或者这两个地方都加上也是可以的
只在参数所在的方法上添加是没有任何用的
在这里插入图片描述
上面的方法是对的,但是想做到成功还需要面对一个重要的问题,nacos版本问题!

这个问题搞了我好久,之前尝试了很多方法都没有用,最后定位问题出在版本上
后来我尝试换像springboot版本,nacos config版本,nacos client版本,这些网上的方法我经尝试全都没得用。。。

最后我把nacos client去掉,然后重启项目,访问测试地址,为20。

再在nacos配置中心修改参数值(这里将20修改为30)然后发布,再次访问测试地址显示30(前提不用重启项目),说明自动刷新配置成功
在这里插入图片描述

在这里插入图片描述
最后猜想这个确实是版本问题,但是正常的直接修改版本号还没有用
好像是直接是nacos client和nacos config这两个东西冲突(它两个原本是一起用的)
将nacos client删掉就好了。。。。好奇怪,正常思路还真不好解决!算是凑巧解决了

附上我成功的版本号:

     #spring boot<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.2.RELEASE</version></parent>#nacos config<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId><version>2.2.6.RELEASE</version></dependency>#nacos discovery<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId><version>2.2.6.RELEASE</version></dependency>
#nacos client 注释掉
<!--        <dependency>-->
<!--            <groupId>com.alibaba.nacos</groupId>-->
<!--            <artifactId>nacos-client</artifactId>-->
<!--            <version>2.0.3</version>-->
<!--        </dependency>-->

续:如果遇到参数太多的情况,比如有多个文件都有需要注入的参数的情况
我们可以把这些参数规整到一个文件中进行管理,还是上面这个例子

在这里插入图片描述
使用参数时直接从CodeConststant中调用就行了
在这里插入图片描述

然后我发现这样做除了很方便参数的管理外,还不用在所用到参数的类上都加上@ResoureScope自动刷新注解
只需要在管理参数的这个配置文件类上加上@ResourceScope注解就行了

上面演示的是非静态的变量注入的方式,那么静态变量注入又麻烦一些,我给大家看一下:

注入静态变量需要注意以下几点:

  1. 使用set方法注入
  2. @Value注解要加在set方法上
  3. set方法要去掉static

在这里插入图片描述
在这里插入图片描述
然后我发现这样常规的获取静态方法虽然成功了,但是不能够实现值的动态刷新。
进一步试验,我发现在本类中这样获取静态变量,是可以实现数据源动态刷新的
但是像上面这样把静态变量归到另一个类中管理,本类通过调用的方式取静态变量就不能实现刷新
猜想可能是因为从不同类的地方取静态变量时有限制,静态变量在获取后不能够刷新,在使用的时候才能够更新
所以我尝试在获取(set)静态变量后,再使用(get),这样从另一个类中调用的时候就能拿到刷新的值了
注意:get这里和set一样把自动生成的static(Setter方法的时候)去掉
在这里插入图片描述

之前直接获取静态变量不能实现动态刷新:

在这里插入图片描述
现在通过获取静态变量的get方法取值可以实现动态刷新:
在这里插入图片描述
经验是一点点尝试出来的,解决这个问题耗时两天,好在现在成功解决了!伙伴们有同样需求可以直接借鉴!

在这里插入图片描述

这篇关于nacos配置中心动态刷新数据源成功经验 | 大别山码将的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/272130

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

跨国公司撤出在华研发中心的启示:中国IT产业的挑战与机遇

近日,IBM中国宣布撤出在华的两大研发中心,这一决定在IT行业引发了广泛的讨论和关注。跨国公司在华研发中心的撤出,不仅对众多IT从业者的职业发展带来了直接的冲击,也引发了人们对全球化背景下中国IT产业竞争力和未来发展方向的深思。面对这一突如其来的变化,我们应如何看待跨国公司的决策?中国IT人才又该如何应对?中国IT产业将何去何从?本文将围绕这些问题展开探讨。 跨国公司撤出的背景与

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d