在上一篇文章中已经实现了Spring Cloud的配置与程序隔离,使用Git实现了配置中心,
但是每次修改配置文件,都需要重启Spring Cloud服务才能加载,这是个很大的问题,其实这个问题还是有解决方式的,spring cloud支持通过AMQP来实现配置的实时更新。
以下是配置自动更新的相关配置:
一、安装RabbitMQ
具体安装可以参考之前的文章:https://blog.csdn.net/vtopqx/article/details/81777003
二、创建消费者:service-consumer-config
在根目录spring_cloud中创建Maven Moudle模块:service-consumer-config
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spring-cloud</artifactId>
<groupId>com.sam</groupId>
<version>0.0.1</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>service-consumer-ribbon</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
</dependency>
<!-- 使用配置中心 -->
<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>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
</project>
注:spring-boot-starter-actuator是spring-boot自带的监控模块,我们要使用spring-cloud-starter-bus-amqp的话,也必须加上。
同时在之前的config-server 配置中心服务中,也需要添加,添加如下依赖:
<!-- 使用动态配置 -->
<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>
创建Controller类:TestController
package com.sam.service.consumer.config;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
/**
* @ClassName: TestController
* @Description: [测试]配置中心
* @author sam
* @date 2018年8月10日 下午2:56:02
*/
@RestController
@RefreshScope
public class TestController {
@Autowired
RestTemplate restTemplate;
@RequestMapping("/hi")
public String hi(@RequestParam String id) {
return restTemplate.getForObject("http://service-producer/hi?id=" + id, String.class);
}
@Value("${ip}")
private String ip;
@Value("${port}")
private String port;
@RequestMapping("/getProperties")
public String getProperties() {
return ip + " : " + port;
}
}
创建配置文件:application.yml
server:
port: 8913
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8010/eureka/
spring:
application:
name: service-consumer-config
cloud:
config:
discovery:
enabled: true #开启通过服务来访问Config Server的功能
service-id: config-server
profile: dev
label: master
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
这里和之前配置中心的区别是增加了rabbitmq参数 配置,
创建消费者服务启动类:ClientApplicationConfig
package com.sam.service.consumer.config;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
/**
* @ClassName: ClientApplicationConfig
* @Description: 消费者服务(测试配置中心)
* @author sam
* @date 2018年8月10日 下午4:31:33
*/
@SpringBootApplication
@EnableDiscoveryClient
public class ClientApplicationConfig {
public static void main(String[] args) {
SpringApplication.run(ClientApplicationConfig.class, args);
}
@Bean
@LoadBalanced
RestTemplate restTemplate() {
return new RestTemplate();
}
}
配置完成后,启动 service-consumer-config 等服务,
打开刚新增的消费者服务 http://localhost:8913/getProperties
测试下,修改一下Git上配置文件的内容,
修改提交完成后,需要刷新一下,
POST 访问 config-service 配置中心服务的刷新地址 http://localhost:8030/bus/refresh
注意是:post访问。如果没有报错,状态 HTTP/1.1 200 的话,那就是刷新成功了!
再次访问消费者服务 http://localhost:8913/getProperties 可以看到配置文件参数以及成功读取到最新的了;
以上配置完成了,配置中心配置改变需要重启服务的问题,
三、自动更新:
不过虽然不需要重启服务了,但是还是需要进行手动刷新一次,这也是个麻烦的事情,当然有方式可以解决,
可以设置Git的webhooks来达到自动更新配置,
打开git上配置仓库的地址,添加webhooks:
在Settings中设置URL,需要设置外部可以访问的公网地址,
如上,把 http://localhost:8030/bus/refresh 改成自己的地址,即可实现配置文件提交后,自动进行刷新地址,实现配置自动更新!