springcloud系列30——Spring Cloud Config配置属性自动刷新

标签: springcloud

前言

在前面一节中,我们通过执行/refresh端点来手动刷新配置,但是如果微服务的数量太多,一个一个刷新就很麻烦也很慢。本节介绍使用Spring Cloud Bus实现批量刷新和自动刷新。

使用Spring Cloud Bus实现配置批量刷新

Spring Cloud Bus依赖rabbitmq或kafka,这里我们使用rabbitmq。

1.rabbitmq的安装与使用

进入rabbitmq的下载页面下载安装包(这里使用windows),下载地址为:http://www.rabbitmq.com/download.html

在下载页面的右侧有各个系统的安装方法。

windows的地址为:http://www.rabbitmq.com/install-windows.html

rabbitmq依赖Erlang,所以在安装rabbitmq之前需要安装Erlang。

http://www.rabbitmq.com/which-erlang.html这个页面给出了每个rabbitmq应该安装的Erlang版本。

我们下载的是3.7.7的版本,推荐的Erlang版本是21.0.x 。

erlang的下载地址为:http://erlang.org/download/

csdn下载地址:https://download.csdn.net/download/qq_24118265/10186110

下载完毕后,就依次安装Erlang和rabbitmq即可。

安装完毕后,可以看到rabbitmq已经作为服务启动了。

2.开启RabbitMQ网页端控制台

1.设置ERLANG_HOME环境变量;

2.到rabbitmqhome/sbinrabbitmq_home/sbin执行:

rabbitmq-plugins.bat enable rabbitmq_management

如图:

3.重新开启rabbitmq服务。

4.浏览器访问http://localhost:15672,用户名和密码默认都是guest。

3.Cloud Config Client修改

  1. 增加spring-cloud-starter-bus-amqp依赖;

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-bus-amqp</artifactId>
    </dependency>
    
  2. 增加rabbitmq配置

    spring:
      rabbitmq:
          host: localhost
          port: 5672
          username: guest
          password: guest
    

    如此就大功告成了!

下面进行测试。

启动Config Server和2个Cloud Client(为了测试批量刷新配置)。
在Cloud Client启动时,控制台可以看到有一个端点/bus/refresh,我们用它可以批量刷新配置。
我们将git仓库配置文件的一个配置项做修改:

my.custom.message=Hello,This is new value!!!

我们使用curl执行刷新命令:

curl -X POST http://localhost:8080/bus/refresh

然后访问Cloud Config Client,看看是否配置更新。

可以看到,2个Cloud Config Client应用配置都已经刷新!

观察2个Cloud Config Client,可以看到如下日志:

至此就实现了批量配置刷新。

我们到RabbitMQ的控制台的Exchanges,可以看到springCloudBus。

刷新某个Cloud Config Client

如果要刷新某个Cloud Config Client的配置,可以使用/bus/refresh?destination=customers:9000。其中,customers:这里是ApplicationContext ID,9000是服务的端口。

但是,如果在BUS上已经有了这个ID,则会刷新这个ID的配置,其他的会被忽略。即如果在不同的机器上部署了同样的Cloud Config Client应用,ID一样,端口一样,IP不一样,则只会有一个服务配置属性会被刷新。

解决办法就是制定spring.application.index,不过这样就很麻烦了,每个同类的微服务(ID相同)都需要指定不同的index。不过可以指定spring.application.index=${random.long}来使用随机生成的数字作为index。不过,很明显似乎是一个设计缺陷,为什么不增加一个host参数?

刷新某个Cloud Config Client服务的所有实例

这个比较简单了,使用/bus/refresh?destination=customers:**即可,customers指应用的id。

参考Spring Cloud Bus章节:http://cloud.spring.io/spring-cloud-static/Edgware.SR3/single/spring-cloud.html#_spring_cloud_bus

配置自动刷新

这个要借助于Git管理软件提供的WebHooks钩子,可以指定一个地址,在提交到Git仓库时自动触发请求这个地址。

比如gitee.com

上面的URL就指定为刷新地址,如http://localhost:8080/bus/refresh,密码随意了。

版权声明:本文为qincidong原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qincidong/article/details/82767787

智能推荐

idea基础–(7)–jsp页面Controller路径自动识别的问题“Cannot resolve controller URL ...”,Cannot resolve variable

idea之所以强大,就是强大的代码提示和联想功能,写起代码来简直不要太爽。但是这几天我发现在我的jsp页面中访问controller路径的时候不会自动提示了,对于这么严谨的我肯定要找出原因啊,哈哈。 最终效果:按住ctrl,同时点击左键会自动跳转到对应的controller代码块,爽。 需要同时满足的条件 JSP页面顶部包含如下代码: 在idea的项目设置中显示如下:  若显示的是spring a...

26_Python基础_继承

面向对象三大特性: 封装 根据 职责 将 属性 和 方法 封装 到一个抽象的 类 中 继承 实现代码的重用, 相同的代码不需要重复的编写 多态 不同的对象调用相同的方法,  产生不同的执行结果,  增加代码的灵活度 1.  单继承 1.1 概念 继承的概念:&...

循环

与任何程序设计语言一样Java利用条件语句与循环结构确定流程控制,一下总结一下Java中的循环语句: while do while for switch 对于golang来说: switch非常灵活。从第一个expr为true的case开始执行,如果case带有fallthrough,程序会继续执行下一条case,不会再判断下一条case的expr,如果之后的case都有fallthrough,d...

1638 统计只差一个字符的子串数目(动态规划)

1. 问题描述: 给你两个字符串 s 和 t ,请你找出 s 中的非空子串的数目,这些子串满足替换一个不同字符以后,是 t 串的子串。换言之,请你找到 s 和 t 串中恰好只有一个字符不同的子字符串对的数目。比方说, "computer" 和 "computation"...

websocket基本原理

HTTP中一个request只能有一个response。而且这个response也是被动的,不能主动发起 因此过去的服务端推送信息是通过客户端不停的轮询实现的 websocket是双向通信协议,提供了服务端主动推送信息的能力 需要客户端(浏览器)和服务端同时支持 如果经过代理的话,还需要代理支持,否则有些代理在长时间无通信时会自动切断连接 因此WS为了保证连接不被断掉,会发心跳 WebSocket...

猜你喜欢

mybatis+ehcache二级缓存

导入jar包 mapper.xml文件开启二级缓存 pojo类实现序列化接口 配置ehcache.xml 测试...

python+opencv实现图像拼接

任务 拍摄两张图片去除相同部分,拼接在一起 原图 结果 步骤 读取两张图片 使用sift检测关键点及描述因子 匹配关键点 处理并保存关键点 得到变换矩阵 图像变换并拼接 代码实现 扩展 这里对右边图像进行变换,右边变得模糊,可以修改代码对左边图像变换 这里只有两张图片拼接,可以封装实现多张图片拼接 可以修改代码实现上下图片的拼接...

python_sklearn机器学习算法系列之AdaBoost------人脸识别(PCA,决策树)

          注:在读本文之前建议读一下之前的一片文章python_sklearn机器学习算法系列之PCA(主成分分析)------人脸识别(k-NearestNeighbor,KNN)         本文主要目的是通过一个简单的小...

memmove函数与memcpy函数的模拟实现

memmove函数和memcpy函数都是在内存复制任意类型的,但是它俩也有区别。当源区域和目标区域有重复的,memmove函数会复制缓冲区重叠的部分,而memcpy相反,会报出未知错误。 下面给出两个函数的实现 首先,memmove函数。 实现的基本原理如下图。 具体代码如下: memcpy函数的实现很简单,就直接给出源代码了...