上一节主要说明了怎么加入统一配置中心的组件,并从git上获取配置信息,可以实现所有微服务组件的配置统一管理,那如果微服务的配置修改了是不是还得跑回去重启微服务呢?如果有上百个微服务呢?这时候springCloud就提供了一种通过消息机制自动刷新配置,而且实现热更新无缝切换配置,下面就开始说明如何实现配置文件的自动刷新
除了自动刷新多个微服务的机制,也有单个微服务配置手动刷新的方法,手动刷新一般很少会用到,这里主要讲述多个微服务自动刷新
目录
1、给配置中心模块添加依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bus-amqp</artifactId> </dependency> <!--服务客户端 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>
2、修改配置中心配置文件
主要是连接rabbitmq,以及注册到服务中心中,还有一个开启所有端点,主要是bus-refresh端点
server: port: 8804 spring: application: name: cloud-config cloud: config: server: git: uri: git@gitee.com:apgblogs/springCloudStudyConfig.git rabbitmq: host: apg-server port: 5672 username: guest password: guest eureka: client: service-url: defaultZone: http://localhost:8801/eureka/ instance: prefer-ip-address: true management: endpoints: web: exposure: include: "*"
3、给用户和订单微服务都加入以下依赖
在这两个模块的pom文件中分别加入以下两个依赖
<!--云配置依赖 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bus-amqp</artifactId> </dependency>
4、将用户和订单微服务的application的配置文件放入git仓库中
在仓库中创建以下几个配置文件
data:image/s3,"s3://crabby-images/1368e/1368e6b08e3afdd44e5d7ca72399151b7768232d" alt=""
cloud-user-dev.yml配置文件
data:image/s3,"s3://crabby-images/17f5c/17f5c8927677d080bc4b133c18c7f111f72048ca" alt=""
cloud-order-dev.yml配置文件
data:image/s3,"s3://crabby-images/f16c7/f16c7ad574c8eb83e2be53adf92c10b5cd08449f" alt=""
5、给用户和订单微服务都新建bootstrap.yml文件
用户bootstrap.yml文件
用于连接rabbitmq,连接配置中心
spring: cloud: config: label: master profile: dev discovery: enabled: true service-id: cloud-config application: name: cloud-user rabbitmq: host: apg-server port: 5672 username: guest password: guest eureka: client: service-url: defaultZone: http://localhost:8801/eureka/ instance: prefer-ip-address: true
订单bootstrap.yml文件
spring: cloud: config: label: master profile: dev discovery: enabled: true service-id: cloud-config application: name: cloud-order rabbitmq: host: apg-server port: 5672 username: guest password: guest eureka: client: service-url: defaultZone: http://localhost:8801/eureka/ instance: prefer-ip-address: true
6、给用户和订单微服务都加入一个获取配置文件的地址用来测试
UserController中加入以下代码
@RefreshScope 加入此注解才能刷新此类中的配置
data:image/s3,"s3://crabby-images/efa6a/efa6add9a8911170b0f092a9438f84ffe560302c" alt=""
OrderController中加入以下代码,跟UserController是一样的
data:image/s3,"s3://crabby-images/a6ed0/a6ed0a657520e4b23556e8628426e2898ed4165e" alt=""
7、启动服务发现,配置中心,用户和订单四个微服务
启动时如果出现报错的话,请按先后顺序启动,先启动服务中心,再启动配置中心,再启动其他两个微服务
data:image/s3,"s3://crabby-images/339fa/339fa6e0032a9f34359324fbe36badc1b4e0b2f0" alt=""
8、访问用户和订单微服务中getEnvName的地址
用户环境变量获取如下
data:image/s3,"s3://crabby-images/f1075/f1075ee7b52ed5c94a3f0007e03eb1672fc150b6" alt=""
订单环境变量获取如下
data:image/s3,"s3://crabby-images/31888/318881cdbafd5d6b8273a895d35f08acbc2b9ed6" alt=""
9、修改git仓库中用户和订单配置文件的envName值
将仓库中用户和订单的配置envName都修改了
cloud-user-dev.yml
envName: devUser3
cloud-order-dev.yml
envName: devOrder3
10、访问配置中心的bus-refresh端点对配置文件进行刷新
在postman中用post请求以下地址,即可对配置文件刷新
http://localhost:8804/actuator/bus-refresh
再去访问刚刚两个地址看看结果是不是变了
data:image/s3,"s3://crabby-images/5e248/5e248ed7a6d4de89334d87e1d530ef92f6038fb0" alt=""
data:image/s3,"s3://crabby-images/24cb7/24cb7204bce52590a22acc2ec772a3ff9aae9dff" alt=""
11、文章源码地址
码云:https://gitee.com/apgblogs/springCloudStudy/tree/configRefresh/