通过bus组件,可以在更新git配置信息后,通过发送一个post请求,更新《server-config》拉取的配置,并以RabbitMQ将更新内容广播至其对应的各个微服务;
本篇前置:
SpringCloud极简入门>配置服务#config
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配置值;
application.yml添加
#支持busmanagement: 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将更新内容广播至其对应的各个微服务;