tft每日頭條

 > 圖文

 > springcloudconfig是什麼

springcloudconfig是什麼

圖文 更新时间:2024-05-16 00:03:20
Config配置中心

在采用分布式微服務架構的系統中,由于服務數量衆多,為了方便服務配置文件的統一管理,需要分布式配置中心組件。如果分散管理各個服務的配置,那麼上線之後的配置如何保持一緻将會是一個很讓人頭疼的問題。

因此,各個服務的配置定然需要集中管理。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所示。

springcloudconfig是什麼(一文帶你弄明白Spring)1

圖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所示。

springcloudconfig是什麼(一文帶你弄明白Spring)2

圖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配置中心
  1. 下篇文章給大家講解的是微服務的RPC遠程調用;
  2. 覺得文章不錯的朋友可以轉發此文關注小編;
  3. 感謝大家的支持
,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关圖文资讯推荐

热门圖文资讯推荐

网友关注

Copyright 2023-2024 - www.tftnews.com All Rights Reserved