在采用分布式微服務架構的系統中,由于服務數量衆多,為了方便服務配置文件的統一管理,需要分布式配置中心組件。如果分散管理各個服務的配置,那麼上線之後的配置如何保持一緻将會是一個很讓人頭疼的問題。
因此,各個服務的配置定然需要集中管理。Spring Cloud Config配置中心是一個比較好的解決方案。使用Spring Cloud Config配置中心涉及兩部分内容:
(1)config-server:服務端配置。
(2)config-client:客戶端配置。
config-server服務端組件通過Spring Cloud構建一個config-server服務大緻需要3步。首先,在pom.xml中引入spring-cloud-Config-server依賴,如下所示:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
其次,在所創建的Spring Boot程序的啟動類上添加@EnableConfigServer注解,開啟Config Server服務,代碼如下:
@EnableConfigServer
@SpringBootApplication
public class Application {
public static void main(String[] args) {
new SpringApplicationBuilder(Application.class).
web(true).run(args);
}
}
最後,設置屬性文件的位置。Spring Cloud Config提供本地存儲配置的方式。在bootstrap啟動屬性文件中,設置屬性spring.profiles.active=native,并且設置屬性文件所在的位置,如下所示:
server:
port: 7788 #配置中心端口
spring:
application:
name: config-server #服務名稱
profiles:
active: native #設置讀取本地配置文件
cloud:
config:
server: native:
searchLocations: classpath:config/ #聲明本地配置文件的存放位置
配置說明:
(1)spring.profiles.active=native,表示讀取本地配置,而不是從Git讀取配置。
(2)search-locations=classpath:config/,表示查找文件的路徑,在類路徑的config下。
服務端的配置文件放置規則:在配置路徑下,以{label}/{application}-{profile}.properties的命令規範放置對應的配置文件。上面的實例放置了以下配置文件:
/dev/crazymaker-common.yml
/dev/crazymaker-db.yml
/dev/crazymaker-Redis.yml
以上文件分别對通用(common)、數據庫(db)、緩存(redis)的相關屬性進行設置。作為示例,緩存(redis)的配置如下:
spring:
redis:
blockWhenExhausted: true #鍊接耗盡時是否阻塞
database: 0 #指定Redis數據庫
host: ${SCAFFOLD_REDIS_HOST:localhost} #Redis主機IP
maxIdle: 100 #最大空閑連接數
maxTotal: 2000 #最大連接數
maxWaitMillis: 60000 #獲取鍊接最大等待毫秒數
minEvictableIdleTimeMillis: 1800000 #最小空閑時間
numTestsPerEvictionRun: 1024 #每次釋放鍊接的最大數目
password: ${SCAFFOLD_REDIS_PSW:123456} #密碼,如果沒有設置密碼,這個配置就可以不設置
port: 6379 #Redis端口
softMinEvictableIdleTimeMillis: 10000 #鍊接空閑多久後釋放
testOnBorrow: false #在使用時檢查有效性
testWhileIdle: true #獲取鍊接時檢查有效性
timeBetweenEvictionRunsMillis: 30000 #釋放鍊接的掃描間隔(毫秒)
connTimeout: 6000 #鍊接超時毫秒數
readTimeout: 6000 #讀取超時毫秒數
Config配置中心啟動之後,可以使用以下地址格式直接訪問加載好的配置屬性:
http://${CONFIG-HOST}: ${CONFIG-PORT}/{application}/{profile}[/{label}]
例如,通過地址
http://192.168.233.128:7788/crazymaker/redis/dev訪問示例中配置的緩存的相關屬性,如圖2-11所示。
圖2-11 返回的配置信息
特别說明:Spring Cloud Config-Server支持多種配置方式,比如Git、Native、SVN等。雖然官方建議使用Git方式進行配置,但是這裡沒有重點介紹Git方式,而是使用了本地文件的方式,有以下3個原因:
(1)對于學習或者一般的開發來說,本地文件的配置方式更簡化。
(2)生産環境建議使用Nacos,其具備注冊中心和配置中心相結合的功能,更加方便與簡單。
(3)掌握了Native的配置方式之後,對于Git的配置方式就能觸類旁通。
config-client客戶端組件客戶端config-client同config-server一樣,需要新增springcloud-starter-eureka的依賴用來注冊服務,然後增加spring-cloudstarter-config依賴引入配置相關的JAR包。
<dependencies>
...
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
</dependencies>
在bootstrap.properties中,按如下規則增加客戶端配置的映射規則:
spring.cloud.config.label:dev #對應服務端規則中的{label}部分
spring.application.name:crazymaker #對應服務端規則中的{application}部分
spring.cloud.config.profile:redis #對應服務端規則中的{profile}部分
spring.cloud.config.uri:http://${CONFIG-HOST}:7788/ #配置中心config-server獨立的uri地址
效果如圖2-12所示。
圖2-12 客戶端配置項與服務端配置文件的映射規則
如果是與Eureka的客戶端配合使用,那麼建議開啟配置服務的自動發現機制,使用如下配置:
spring.cloud.config.discovery.enabled: true
spring.cloud.config.discovery.service-id: config-server
配置中心的兩種發現機制不能同時存在,二者選其一即可。
客戶端config屬性的相關配置隻有配置在bootstrap.properties(或bootstrap.yml)中,config部分的内容才能被正确加載,原因是config的相關配置必須早于application.properties,而bootstrap.properties的加載也早于application.properties。
本文給大家講解的内容是Spring Cloud Config配置中心- 下篇文章給大家講解的是微服務的RPC遠程調用;
- 覺得文章不錯的朋友可以轉發此文關注小編;
- 感謝大家的支持