简介
通过bus组件,可以在更新git配置信息后,通过发送一个post请求,更新《server-config》拉取的配置,并以RabbitMQ将更新内容广播至其对应的各个微服务;
本篇前置:
SpringCloud极简入门>配置服务#config
实战
1、前置准备
1.1、需要开启RabbitMQ服务
cmd以管理员权限执行net stop RabbitMQ && net start RabbitMQ;
1.2、对zipkin有影响
原本cmd执行java -jar zipkin-server-2.10.1-exec.jar,改为java -jar zipkin-server-2.10.1-exec.jar --zipkin.collector.rabbitmq.addresses=localhost;
2、《server-order》项目改造
2.1、添加依赖
actuator可以在修改git配置内容后刷新《server-config》服务拉取的配置值;
bus-amqp可以通过RabbitMQ通知各个微服务刷新获取的git配置值;
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
2.2、yml配置
-
application.yml添加
#支持bus management: endpoints: web: exposure: include: "*" cors: allowed-origins: "*" allowed-methods: "*" -
bootstrap.yml添加
#读取server-config服务上当前服务的git配置 spring: cloud: config: label: main profile: dev discovery: enabled: true service-id: server-config #支持bus bus: trace: enabled: true enabled: true #支持bus rabbitmq: host: localhost port: 5672 username: guest password: guest
2.3、添加注解
在含@Value和@ConfigurationProperties的获取git配置的类上声明注解@RefreshScope;
3、配置完毕,查看效果
1、分别启动《server-center》,《server-config》,《server-order》,请求http://localhost:7002/cfgP,获得结果
GitAutoRefreshConfig{env='dev', user=User{username='catface', password='root'}}
2、修改git上的配置值env=devdevdev;
3、 postman发起post请求http://localhost:7002/actuator/bus-refresh后再访问http://localhost:7002/cfgP,获得结果,可以看到在没有重启服务的情况下,读取的配置文件更新了;
GitAutoRefreshConfig{env='devdevdev', user=User{username='catface', password='root'}}
4、再以7003端口启动《server-order》服务,修改git配置后,操作上述步骤3、后会发现以7002和7003端口读取的配置值均是更新后的,这就是RabbitMQ将更新的git配置广播给了各个微服务;
总结
通过bus组件,可以在更新git配置信息后,通过发送一个post请求,更新《server-config》拉取的配置,并以RabbitMQ将更新内容广播至其对应的各个微服务;

本文介绍了如何使用Spring Cloud的bus-amqp组件,配合actuator进行配置更新,并通过RabbitMQ实现配置广播到各微服务。通过实例演示了配置服务的改造、依赖添加和bus配置,展示了在不重启服务情况下更新git配置并实时生效的过程。
273

被折叠的 条评论
为什么被折叠?



