史上最簡單的SpringCloud教程 | 第六篇: 分散式配置中心(Spring Cloud Config)
最新Finchley版本:
https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f6-config/
或者
http://blog.csdn.net/forezp/article/details/81041028
在上一篇文章講述zuul的時候,已經提到過,使用配置服務來儲存各個服務的配置檔案。它就是Spring Cloud Config。
在分散式系統中,由於服務數量巨多,為了方便服務配置檔案統一管理,實時更新,所以需要分散式配置中心元件。在Spring Cloud中,有分散式配置中心元件spring cloud config ,它支援配置服務放在配置服務的記憶體中(即本地),也支援放在遠端Git倉庫中。在spring cloud config 元件中,分兩個角色,一是config server,二是config client。
建立一個spring-boot專案,取名為config-server,其pom.xml:
在程式的入口Application類加上@EnableConfigServer註解開啟配置伺服器的功能,程式碼如下:
需要在程式的配置檔案application.properties檔案配置以下:
- spring.cloud.config.server.git.uri:配置git倉庫地址
- spring.cloud.config.server.git.searchPaths:配置倉庫路徑
- spring.cloud.config.label:配置倉庫的分支
- spring.cloud.config.server.git.username:訪問git倉庫的使用者名稱
- spring.cloud.config.server.git.password:訪問git倉庫的使用者密碼
如果Git倉庫為公開倉庫,可以不填寫使用者名稱和密碼,如果是私有倉庫需要填寫,本例子是公開倉庫,放心使用。
遠端倉庫https://github.com/forezp/SpringcloudConfig/ 中有個檔案config-client-dev.properties檔案中有一個屬性:
foo=foo version 3
啟動程式:訪問http://localhost:8888/foo/dev
證明配置服務中心可以從遠端程式獲取配置資訊。
http請求地址和資原始檔對映如下:
- /{application}/{profile}[/{label}]
- /{application}-{profile}.yml
- /{label}/{application}-{profile}.yml
- /{application}-{profile}.properties
- /{label}/{application}-{profile}.properties
重新建立一個springboot專案,雅思培訓一般多少錢取名為config-client,其pom檔案:
其配置檔案bootstrap.properties:
-
spring.cloud.config.label 指明遠端倉庫的分支
-
spring.cloud.config.profile
- dev開發環境配置檔案
- test測試環境
- pro正式環境
-
spring.cloud.config.uri=http://localhost:8888/ 指明配置服務中心的網址。
程式的入口類,寫一個API介面“/hi”,返回從配置中心讀取的foo變數的值,程式碼如下:
開啟網址訪問:http://localhost:8881/hi,網頁顯示:
foo version 3
這就說明,config-client從config-server獲取了foo的屬性,而config-server是從git倉庫讀取的,如圖:
本文原始碼下載:
https://github.com/forezp/SpringCloudLearning/tree/master/chapter6