说明:
SpringCloud-Config分为服务端与客户端,Config服务端是一个微服务,供其他每个微服务调用,统一向git仓库获取配置文件。其他每个微服务配置Config客户端,向Config服务端获取配置文件。可以在线改配置,无需重新部署微服务。
SpringCloud-Bus监听配置文件,有改动时通知,实现不重启微服务,让配置生效。
一、导入SpringCloud与SpringBoot依赖包(必须版本对应,此处为2.2.x <-> Hoxton):
见此文章第一章:https://blog.csdn.net/a526001650a/article/details/106859559
二、创建Config服务端(也是个微服务),从git仓库拉取配置文件:
1.导入Config服务端依赖包、Eureka的Client端依赖包,在工程/pom.xml中:
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
org.springframework.cloud
spring-cloud-config-server
2.Config服务端application.yml中配置Config服务端信息:
server:
prot: 8080 #配置此Config服务端端口
spring:
application:
name: mall-config #配置此Config服务端服务名称
cloud:
config:
server:
git: #存放每个微服务配置文件的git仓库地址
uri: https://gitee.com/wuwei_yyh/mall-config.git
#username: yangyh #git用户名
#password: 12345678 #git密码
#需要导入Eureka Server信息,否则无法连接
eureka:
client:
service-url: #导入Eureka Server配置的地址
defaultZone: http://127.0.0.1:10000/eureka/
3.在Application启动类上添加Config服务端注解:
@SpringBootApplication //标识为启动类
@EnableConfigServer //配置为Config服务端
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class); //加载启动类
}
}
三、每个微服务Module中配置Config客户端(用于访问上面的Config服务端拉取git仓库的配置文件):
说明:此处微服务工程中为mall-usercenter,在git仓库的配置文件为usercenter-dev.yml
1.导入Config客户端依赖包,在工程/pom.xml中:
org.springframework.cloud
spring-cloud-starter-config
2.resources目录下添加bootstrap.yml(不要创建application.yml):
spring:
cloud:
config:
name: usercenter #git仓库文件"usercenter-dev.yml"-前部分
profile: dev #git仓库文件"usercenter-dev.yml"-后部分
label: master #git仓库文件所在分支
uri: http://127.0.0.1:8080 #Config服务端地址与端口
3.每个微服务一个配置文件,需要手动上传到git仓库,命名方式:name-dev,此处为usercenter-dev.yml,内容如下:
spring:
application:
name: mall-usercenter #配置当前微服务名称
rabbitmq: #配置rabbitmq服务器的地址和端口,rabbitmq服务器需要另外安装
host: 192.168.3.119
port: 5672
#username: yangyh #登录用户名
#password: 12345678 #登录密码
server: #配置端口号
port: 10001
eureka:
client:
service-url: #导入Eureka Server配置的地址
defaultZone: http://127.0.0.1:10000/eureka/
key1: value1 #自定义字段
4.mall-usercenter微服务运行后会将usercenter-dev.yml配置文件下载并应用,可以在浏览器输入地址测试,网页上显示配置文件的信息则表示成功了。
#在浏览器中访问Config服务端地址+mall-usercenter的配置文件名称
http://127.0.0.1:8080/usercenter-dev.yml
四、Bus消息总线监听,实现不重启微服务,让配置生效:
1.Config服务端配置暴露触发消息总线的地址:
(1)导入Bus和Rabbit依赖包:
org.springframework.cloud
spring-cloud-bus
org.springframework.cloud
spring-cloud-stream-binder-rabbit
(2)Config服务端application.yml中配置rabbitmq服务器和Bus信息:
...
spring:
...
rabbitmq: #配置rabbitmq服务器的地址和端口,rabbitmq服务器需要另外安装
host: 192.168.3.119
port: 5672
#username: yangyh #登录用户名
#password: 12345678 #登录密码
management: #对客户端暴露发送消息的地址:http://192.168.3.119:5672/actuator/bus-refresh
endpoints:
web:
exposure:
include: bus-refresh #此值对应上面的消息地址
2.Config客户端(其他每个微服务)配置监听消息:
(1)导入Bus和Rabbit和Actuator监听依赖包:
org.springframework.cloud
spring-cloud-bus
org.springframework.cloud
spring-cloud-stream-binder-rabbit
org.springframework.boot
spring-boot-starter-actuator
(2)在git仓库的usercenter-dev.yml中配置rabbitmq地址:
spring:
rabbitmq: #配置rabbitmq服务器的地址和端口,rabbitmq服务器需要另外安装
host: 192.168.3.119
port: 5672
#username: yangyh #登录用户名
#password: 12345678 #登录密码
(3)手动请求以下地址,发一条rabbitmq消息,通知配置文件更新:
URL:http://192.168.3.119:5672/actuator/bus-refresh
请求方式:POST
(4)默认情况下,只有系统键值对被修改时才能实时生效,想让自定义的键值对修改时也能不重启服务,需要给类加上@RefreshScope注解:
@RefreshScope //此注解能让自定义的键值对修改时也能不重启服务生效
public class UserController {
@Value("${key1}") //在git仓库-usercenter-dev.yml中自定义的键值对
private String key1;
...
}