Spring Cloud教程 第十二弹 Spring Cloud Config整合Spring Cloud Bus实现配置动态刷新
原创
©著作权归作者所有:来自51CTO博客作者wx5df643be5259a的原创作品,请联系作者获取转载授权,否则将追究法律责任
Spring Cloud Config整合Spring Cloud Bus
- 1、回顾
- 2、手动刷新
- 3、Spring Cloud Bus动态刷新配置
1、回顾
在上一弹:Spring Cloud教程 第十一弹 Spring Cloud Config连接git和数据库 中介绍了spring cloud config的基本使用,但是配置无法动态刷新,也就是说如果我更改了git或数据库中的配置,项目必须重新启动才能使新配置生效。
注意:
- 更新配置后,调用config server的HTTP接口是可以获取到新配置的,这是因为config server会实时请求git或数据库,配置当然是最新的,但是config client是感知不到的
下面介绍两种不重启项目便可以刷新配置的方式:
- 手动刷新
- 整合Spring Cloud Bus实现动态刷新
2、手动刷新
步骤如下。
- config client项目的pom.xml中引入spring-boot-starter-actuator依赖,如下所示:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
- config client配置端点,如下所示:
management:
endpoints:
web:
exposure:
include: "*"
- 在需要动态刷新的Bean上打@RefreshScope,如下所示:
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RefreshScope
public class DynamicRefreshController {
@Value("${stuName:\"\"}")
private String stuName;
@GetMapping("/config")
public void init(){
System.out.println("stuName="+stuName);
}
}
- 当修改git、数据库配置时,POST请求config client路径/actuator/refresh,即可手动刷新
3、Spring Cloud Bus动态刷新配置
Spring Cloud Bus 实现配置的动态刷新步骤:
- 当git中的配置发生改变后,向config server发送一个 POST请求,请求路径为/actuator/bus-refresh
- config server接收到请求后,会将该请求转发给服务总线Spring Cloud Bus
- Spring Cloud Bus接到消息后,生成Topic然后会通知给所有config client
- config client接收到通知,请求config server拉取最新配置
Spring Cloud Bus需要引入RabbitMQ或Kafka作为消息传输的媒介。
与手动刷新不同,动态刷新的改造主要在config server项目中。
步骤如下:
- config server项目中的pom.xml引入依赖,如下所示:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
- config server配置端点,如下所示:
management:
endpoints:
web:
exposure:
include: "*"
- 安装并运行RabbitMQ
参考文章:RabbitMQ入门教程
- config server配置RabbitMQ
spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
5.config client引入依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
- config client配置RabbitMQ
spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
bus-refresh端点原理:
- /actuator/bus-refresh端点清除RefreshScope缓存并且重新绑定@ConfigurationProperties