为上一讲解的加深和扩充:微服务工程构建(十一)SpringCloud config分布式配置中心(1.半自动)
Gateway
一.概念
Bus支持两种消息代理:RabbitMQ和Kafka
Spring Cloud Bus配合Spring Cloud Config使用可以实现配置的动态刷新
1.能做什么
spring cloud bus能管理和传播分布式系统间的消息,就像分布式执行器,可用于广播状态更改、时间推送等,也可以当做微服务间的通信通道
spring cloud bus在整个后端服务中起到联通的作用,比如我们需要更新整体配置,只需在git上发布新版本,并对修改点服务端发送命令,bus在监听的情况下会对所有关联的客户端更新消息。
二.RabbitMQ环境配置
1.安装Erlang,下载地址:http://erlang.org/download/
我下载的版本 点下一步就可以了
2.安装RabbitMQ,下载地址:https://dl.bintray.com/rabbitmq/all/rabbitmq-server/
安装好进入
输入以下命令启动管理功能:
rabbitmq-plugins enable rabbitmq_management
访问看是否安装成功:http://localhost:15672/
输入账号密码并登录: guest guest
三.SpringCloud Bus动态刷新全局广播
1.设计思想
当前spring cloud bus提供了两个可用的接口:1./bus/env用于设置某一个配置项2./bus/refresh用于刷新所有绑定到刷新点的配置项。
2.新建 module springcloud-config-client3006
pom
引入actuator监控重要
<dependencies>
<!--客户端config -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>com.psf.springcloud</groupId>
<artifactId>springcloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--POM引入actuator监控 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
bootstrap.yml配置
server:
port: 3006
spring:
application:
name: config-client
cloud:
config:
label: master #分支名称
name: config #配置文件名称
profile: dev #读取后缀名称
uri: http://localhost:3001 #http://localhost:3001/master/config-dev.yml
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka
management:
endpoints:
web:
exposure:
include: "*"
启动类
@SpringBootApplication
public class ConfigClientMain3005 {
public static void main(String[] args) {
SpringApplication.run(ConfigClientMain3005.class,args);
}
}
业务类
@RestController
//这里面的属性有可能会更新的,git中的配置中心变化的话就要刷新,没有这个注解内,配置就不能及时更新
@RefreshScope
public class ClientController {
@Value("${name}")
private String name;
@Value("${age}")
private String age;
@Value("${config.version}")
private String port;
@GetMapping("/getProperties")
public String GetProperties(){
return this.name+" \t"+this.age+"\t"+port;
}
}
服务端3001 客户端3005在
微服务工程构建(十一)SpringCloud config分布式配置中心(1.半自动)
3.给springcloud-config-server3001配置中心服务端添加消息总线支持
pom添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
yml添加
server:
port: 3001
#服务名字
spring:
application:
name: config-server
cloud:
config:
server:
git:
#git 仓库的地址
uri: https://github.com/psfloveni/springcloud-config.git
#git 仓库的账号密码
search-paths:
- springcloud-config
#加入注册中心,实现高可用
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka/
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
management:
endpoints:
web:
exposure:
include: 'bus-refresh'
4.给springcloud-config-client3005和3006客户端添加消息总线支持
pom添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
3005 yml
server:
port: 3005
spring:
application:
name: config-client
cloud:
config:
label: master #分支名称
name: config #配置文件名称
profile: dev #读取后缀名称
uri: http://localhost:3001 #http://localhost:3001/master/config-dev.yml
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka
#暴露监控端口
management:
endpoints:
web:
exposure:
include: "*"
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
3006 yml
server:
port: 3006
spring:
application:
name: config-client
cloud:
config:
label: master #分支名称
name: config #配置文件名称
profile: dev #读取后缀名称
uri: http://localhost:3001 #http://localhost:3001/master/config-dev.yml
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka
#暴露监控端口
management:
endpoints:
web:
exposure:
include: "*"
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
启动 eureka7001—config3001-client3005和3006
springcloud-eureka-server7001 项目
5.发送Post请求:一次发送,处处生效
curl -X POST "http://localhost:3001/actuator/bus-refresh"
修改git配置中心 版本号
只需要执行服务端,其余客户端会自动生效。
如果不想全部通知,只想定点通知
例如:只通知3005更新,不通知3006
公式:http://localhost:配置中心的端口号/actuator/bus-refresh/{destination}
curl -X POST "http://localhost:3001/actuator/bus-refresh/config-client:3005"
四.结论
五.代码下载
代码下载
其余:
微服务工程构建(十)spingcloud整合Gateway(网关)
微服务工程构建(九)spingcloud整合eureka、 Hystrix断路器的降级、熔断、图形化
微服务工程构建(八)eureka环境OpenFeign使用
微服务工程构建(四) eureka集群环境构建 server与server之间相互注册配置 client修改成多个注册
END