1. 程式人生 > >Spring Cloud 進階之路 -- 訊息匯流排 Spring Cloud Bus 配置手動重新整理和動態自動重新整理

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,也可以看到日誌在跑了,說明呼叫成功,然後再訪問之前測試配置檔案更新的地址,可以拿到修改後的配置,完成。