Spring Cloud 進階之路 -- 消息總線 Spring Cloud Bus 配置手動刷新和動態自動刷新

Spring Cloud Bus 配置步驟:

1、Spring Cloud Config 項目引入依賴,添加配置,配置暴露 endpoints

2、啓動Config 項目,註冊到Eureka,自動添加RabbitMQ隊列

3、客戶端的order應用引入依賴及配置,啓動Config 項目,註冊到Eureka,自動添加RabbitMQ隊列

4、修改一下 git 上的配置

5、調用 /actuator/bus-refresh 手動刷新

6、訪問 order 的 getEvn 地址,成功獲取到修改後的值

7、自動刷新

 

詳細如下:

1、Spring Cloud Config 項目引入依賴:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

添加配置,配置暴露 endpoints:

management:
  endpoints:
    web:
      exposure:
        include: "*"

include: "*" 表示暴露所有 endpoints 出去,默認是“health”,“info”

2、啓動Config 項目,註冊到Eureka,啓動成功後會自動添加RabbitMQ隊列

 

3、客戶端的order應用引入依賴 

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

  配置 bootstrap.yml  增加 cloud.config 相關配置:

spring:
  application:
    name: order
  cloud:
    config:
      discovery:
        enabled: true
        # 對應註冊到Eureka中的配置中心應用名
        service-id: CONFIG
      profile: dev
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

  啓動Config 項目,註冊到Eureka,啓動成功後同樣會自動添加RabbitMQ隊列

 

4、修改 git 上的配置,將dev 改爲 dev2

5、調用 /actuator/bus-refresh 手動刷新(POST請求)

http://localhost:8080/actuator/bus-refresh

 這裏用了 Postman 做POST請求 bus-refresh:

6、訪問 order 的 getEvn 地址,成功獲取到 dev2

      這裏要注意使用配置時要加註解 @RefreshScope 

 

7、配置自動刷新

      7.1   CONFIG 應用添加 monitor 依賴:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-config-monitor</artifactId>
</dependency>

      7.2   配置 WebHooks :

              Gitee(碼雲) WebHooks 配置方法:

              Github  WebHooks 配置方法:

配置成功後,會在每次 push 代碼後,都會給遠程 HTTP URL 發送一個 POST 請求。

上面的URL需要使用外網可以訪問到的地址,我是用了Natapp,之前寫過一個有關Natapp內網穿透的,點這裏看內網穿透

      7.3   重啓服務後,在git 上修改配置,修改提交後, Webhooks 就會自動發送一個POST請求到你配置的URL,也可以看到日誌在跑了,說明調用成功,然後再訪問之前測試配置文件更新的地址,可以拿到修改後的配置,完成。

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章