《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

06-01 1273阅读

目录

  • Config与Bus整合自动刷新
    • 步骤1:安装RabbitMQ并启动
      • RabbitMQ的安装
      • 步骤2:创建项目
        • 创建Eureka Server
        • 创建config-server
        • 步骤3: 添加依赖
        • 步骤4:Config Client
        • 步骤5:测试运行
        • 问题一
        • 问题二
        • 总结

          Config与Bus整合自动刷新

          微服务A的所有实例都通过Spring Cloud Bus消息总线连接到了一起,每个实例都会从Config Server订阅配置更新事件并获取配置信息。当其中一个微服务节点的/ous/refresh端点被请求时,该实例就会向Spring Cloud Bus消息总线发送一个配置更新事件,其他实例通过Spring Cloud Bus消息总线获得该事件后也会从Config Server获取最新的配置信息并更新配置。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          步骤:

          1.安装RabbitMQ并启动

          2.添加依赖

          3.修改配置文件

          4.改造Config Client

          5.测试运行

          步骤1:安装RabbitMQ并启动

          RabbitMQ的安装

          1.下载erlang,原因在于RabbitMQ服务端代码是使用并发式语言erlang编写的,下载地址:erlang,双击.eerlangxe文件进行安装就好,安装完成之后创建一个名为ERLANG_HOME的环境变量,其值指向erlang的安装目录,同时将%ERLANG_HOME%\bin加入到Path中。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          最后打开cmd命令行,输入erl,如果出现erlang的版本信息就表示erlang语言环境安装成功

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          2.下载RabbitMQ,下载地址:RabbitMQ,同样双击.exe进行安装就好(注意:默认的安装目录是C:/Program Files/…,这个目录中是存在空格符的,我们需要改变安装目录,貌似RabbitMQ安装目录中是不允许有空格的)。

          3.安装RabbitMQ-Plugins,这个相当于是一个管理界面,方便我们在浏览器界面查看RabbitMQ各个消息队列以及exchange的工作情况,安装方法是:打开命令行cd进入rabbitmq的sbin目录,输入:rabbitmq-plugins enable rabbitmq_management命令,稍等会会发现出现plugins安装成功的提示,默认是安装6个插件。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          4.插件安装完之后,在浏览器输入http://localhost:15672进行验证,你会看到下面界面,输入用户名:guest,密码:guest 就可以进入管理界面。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          步骤2:创建项目

          Eureka Server,config-server,config-client

          创建Eureka Server

          1)使用Spring Initializr方式创建一个名称为eureka-server的Spring Boot项目,将Artifact命名为eureka-server,在pom.xml文件中添加Eureka Server依赖。

          方便测试效果,新建一个eureka-server项目作为Config Server的注册中心,

          将eureka-server端口号设置为8761。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          在加载不出来添加,要与springboot版本相符

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          
              4.0.0
              
                  org.springframework.boot
                  spring-boot-starter-parent
                  2.0.6.RELEASE
                   
              
              com.bushuo
              eureka-server
              0.0.1-SNAPSHOT
              eureka-server
              Demo project for Spring Boot
              
              
                  
              
              
                  
              
              
                  
                  
                  
                  
              
              
                  1.8
              
              
                  
                      org.springframework.cloud
                      
                          spring-cloud-starter-netflix-eureka-server
                      
                  
                  
                      org.springframework.boot
                      spring-boot-starter-web
                  
                  
                      org.springframework.boot
                      spring-boot-starter-test
                      test
                  
              
              
                  
                      
                          org.springframework.cloud
                          spring-cloud-dependencies
                          Finchley.SR2
                          pom
                          import
                      
                  
              
              
                  
                      
                          org.springframework.boot
                          spring-boot-maven-plugin
                      
                  
              
          
          

          2):添加Eureka的相关配置

          在全局配置文件application.yml中添加Eureka的相关配置信息。

          《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

          • fetch-registry:

            设置false 时,该Eureka客户端不会从Eureka Server获取服务注册表的信息。这意味着它不会尝试拉取其他服务的信息,通常这在自身就是Server的情况下使用。

          • register-with-eureka:

            设置为 false 时,Eureka 客户端不注册到 Eureka Server。即不将自身信息注册到服务注册表。在 Eureka Server 节点配置中常用,因 Eureka Server 本身无需注册到其他 Eureka Server,单实例时是。

            3):在项目启动类添加@EnableEurekaServer注解

            在项目启动类EurekaServerApplication上添加@EnableEurekaServer注解开启Eureka Server功能。

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            4)测试运行 http://localhost:8761

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            创建config-server

            在config-4下创建config-server,添加依赖,添加配置,在启动类添加注解

            可以参考操作

            依赖

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            配置bootstrap

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            添加启动类注解

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            步骤3: 添加依赖

            Config Server和Config Client与Spring Cloud Bus整合实现配置自动刷新。改造Config Server与Config Client,在各自的pom.xml配置文件中添加spring-cloud-starter-bus-amqp依赖实现配置自动更新与spring-boot-starter-actuator依赖监控系统健康情况的工具。

                    org.springframework.cloud
                    spring-cloud-starter-bus-amqp
                     2.0.0.RELEASE
                
                
                    org.springframework.boot
                    spring-boot-starter-actuator
                
            

            修改配置文件

            改造Config Server和Config Client的配置文件,在配置文件中设置rabbitmq属性的相关配置,包括主机地址、端口号、用户名和密码,如下所示。

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            spring:
              application:
                name: config-client
              cloud:
                config:
                  server:
                    git:
                      uri: https://gitee.com/nobyebye/hello.git
                      username: #自己的gitee用户名
                      password: #密码
                      label: master
              profiles:
                active: dev
              rabbitmq:
                host: localhost
                port: 5672
                username: guest
                password: guest
            server:
              port: 8001
            management:
              endpoints:
                web:
                  exposure:
                    include: "bus-refresh"
            

            步骤4:Config Client

            config-client的bootstrap.yml

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            添加控制器

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            Config Client,在需要动态刷新配置的类ConfigClientApplication上加上注解@RefreshScope。《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            要在gitee的配置文件添加foo,不然没有注解

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            步骤5:测试运行

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            依次启动config-server、config-client项目。启动成功后,使用浏览器访问http://localhost:8002/foo

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            打开cmd输入命令:curl -X POST http://localhost:8769/actuator/bus-refresh。

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            实现Config与Bus整合自动刷新后,系统能做到实时检测配置变更并自动应用,无需额外的人工干预,减少了系统中断时间和重启操作。这不仅提高了系统的稳定性,还能显著提升运维和开发的效率。

            问题一

            idea运行多个端口,没有services的窗口,点击edit Configurations

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            点击Templates->+ springboot,apply,ok了

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            窗口出来了

            《Spring Cloud Config与Bus整合实现微服务配置自动刷新》

            问题二

            整合Bus自动刷新改进了之前的什么问题?

            1. 手动刷新繁琐:以往配置更新后需要手动重启各服务实例,耗时且麻烦。自动刷新可以省去这一过程,让更新更简单快捷。

            2. 减少服务中断:手动重启会导致短暂的服务中断。自动刷新避免了重启,提升了服务的连续性和可用性。

            3. 配置一致性:手动更新可能导致不同实例间配置不一致,带来同步问题。自动刷新确保所有实例同步更新,保持一致性。

            4. 降低运维复杂性:自动刷新减少了手动操作,降低运维负担,避免人为失误。

            5. 提高实时性:配置更新可实时应用,服务能更快地响应变化,提高了系统的适应性和灵活性。

            总结

            通过整合Spring Cloud Config与Bus实现配置自动刷新,可以在无需重启服务的情况下更新微服务配置。该机制减少了运维干预,提升了系统的稳定性和运维效率,尤其在快速变更的环境中十分实用。

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码