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