1. 程式人生 > >史上最簡單的SpringCloud教程 | 第六篇: 分散式配置中心(Spring Cloud Config)

史上最簡單的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倉庫讀取的,如圖:

Azure (2).png

本文原始碼下載:
https://github.com/forezp/SpringCloudLearning/tree/master/chapter6