首页
/
每日頭條
/
圖文
/
springcloudconfig是什麼
springcloudconfig是什麼
更新时间:2024-05-05 17:51:38
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. 感謝大家的支持
,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
讀了圓明園有什麼樣的感受
讀了圓明園有什麼樣的感受
未曾見過你昔日的輝煌,隻見你滿目瘡痍,留下的是恥辱,更多的是後人需銘記的曆史與教訓!這每一磚一每瓦都是曆史的見證!枯藤老樹昏鴉下已無小橋流水人家,西風依舊北風依舊人不同而已。若時光可倒流,我定會盡我所能護你容顔長存!若曆史可改寫,相信我千千...
2024-05-05
關于玉案的詩詞
關于玉案的詩詞
青玉案,詞牌名,又名“一年春”“西湖路”“青蓮池上客”等。以賀鑄詞《青玉案·淩波不過橫塘路》為正體,雙調六十七字,前後段各六句五仄韻。另有雙調六十七字,前後段各六句、四仄韻;雙調六十八字,前後段各六句、四仄韻等十二種變體。代表作品有辛棄疾《...
2024-05-05
關于紋身的常識
關于紋身的常識
以往紋身在刻闆印象中是叛逆的象征,但随着時代的不同,紋身已經成為藝術的一種,因此可以發現,近幾年來,紋身的人數明顯增加,而且圖案的風格越來越時髦,不再隻有紋龍紋鳳的選項呢!但你知道嗎,想要紋出一個漂亮的圖案之前,不僅要先做好行前動作,紋身完...
2024-05-05
到底怎麼寫入團申請書
到底怎麼寫入團申請書
貴池共青團貴池青年聚集地編輯|盧敏審核|舒雙雙來源|團建頭條聲明|文章部分圖文版權歸原創作者所有,如有侵權請與我們聯系删除。,
2024-05-05
搬家需要注意的細節問題有哪些
搬家需要注意的細節問題有哪些
最近有人問小運詳細的搬家流程,小運理解上班族早出晚歸,沒有時間搬家,搬家确實費心費時費力,所以整理出來了這篇搬家流程,做好以下工作,整個搬家過程就會變得迅速又順利。搬家前:1.斷舍離清理可以根據使用頻率、實際價值來判斷,比如平時用得很少的電...
2024-05-05
Copyright 2023-2024 - www.tftnews.com All Rights Reserved