JavaEE:SpringCloud-使用Config统一管理每个微服务配置文件

说明:

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;
    ...
}

 

你可能感兴趣的:(JavaEE)