SpringCloud- 微服務(wù)為什么需要使用分布式配置中心?

作者:波波烤鴨
dpb-bobokaoya-sm.blog.csdn.net/article/details/93652805
一、 為什么需要使用配置中心
1 服務(wù)配置的現(xiàn)狀
2 常用的配置管理解決方案的缺點(diǎn)
3 為什么要使用 spring cloud config 配置中心?
4 spring cloud config配置中心,它解決了什么問題?
二、 編寫配置中心入門案例
1.編寫配置中心的服務(wù)端
1.1 創(chuàng)建服務(wù)端項(xiàng)目
創(chuàng)建一個(gè)SpringCloud項(xiàng)目。
1.2 修改pom文件
我們需要添加config-server的依賴,具體如下
<project?xmlns="http://maven.apache.org/POM/4.0.0"?xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
?xsi:schemaLocation="http://maven.apache.org/POM/4.0.0?http://maven.apache.org/xsd/maven-4.0.0.xsd">
?<modelVersion>4.0.0modelVersion>
?<parent>
??<groupId>org.springframework.bootgroupId>
??<artifactId>spring-boot-starter-parentartifactId>
??<version>1.5.13.RELEASEversion>
?parent>
?<groupId>com.bobogroupId>
?<artifactId>config-serverartifactId>
?<version>0.0.1-SNAPSHOTversion>
?<dependencyManagement>
??<dependencies>
???<dependency>
????<groupId>org.springframework.cloudgroupId>
????<artifactId>spring-cloud-dependenciesartifactId>
????<version>Dalston.SR5version>
????<type>pomtype>
????<scope>importscope>
???dependency>
??dependencies>
?dependencyManagement>
?<dependencies>
??<dependency>
???<groupId>org.springframework.bootgroupId>
???<artifactId>spring-boot-starter-webartifactId>
??dependency>
??<dependency>
???<groupId>org.springframework.cloudgroupId>
???<artifactId>spring-cloud-starter-eurekaartifactId>
??dependency>
??<dependency>
???<groupId>org.springframework.cloudgroupId>
???<artifactId>spring-cloud-config-serverartifactId>
??dependency>
?dependencies>
?<build>
??<plugins>
???<plugin>
????<groupId>org.springframework.bootgroupId>
????<artifactId>spring-boot-maven-pluginartifactId>
???plugin>
??plugins>
?build>
project>
123456789101112131415161718192021222324252627282930313233343536373839404142434445
1.3 修改配置文件
在此處的配置文件中我們需要關(guān)聯(lián)碼云或者GitHub。以碼云為例
碼云處理
首先我們需要在碼云上注冊(cè)一個(gè)賬號(hào)(https://gitee.com) 然后創(chuàng)建一個(gè)新的項(xiàng)目。
配置文件處理
在配置文件中添加如下配置
spring.application.name=config-server
server.port=9050
#?設(shè)置服務(wù)注冊(cè)中心地址,指向另一個(gè)注冊(cè)中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/
#Git?配置
spring.cloud.config.server.git.uri=https://gitee.com/dengpbs/config
#spring.cloud.config.server.git.username=
#spring.cloud.config.server.git.password=
123456789
創(chuàng)建四個(gè)配置文件
四個(gè)配置文件都有一個(gè)e-book屬性,只是值不一樣。然后將這個(gè)四個(gè)配置文件上傳到碼云中我們新創(chuàng)建的倉(cāng)庫(kù)
然后將項(xiàng)目中的四個(gè)配置文件刪除
1.4 修改啟動(dòng)類
我們需要在啟動(dòng)類中添加eureka客戶端和config服務(wù)端的注解,具體如下:
@SpringBootApplication
@EnableEurekaClient
@EnableConfigServer
public?class?ConfigServerStart?{
?public?static?void?main(String[]?args)?{
??SpringApplication.run(ConfigServerStart.class,?args);
?}
}
123456789
1.5 訪問測(cè)試
啟動(dòng)服務(wù),訪問測(cè)試 http://localhost:9050/config-client/test
http://localhost:9050/config-client/default
http://localhost:9050/config-client/dev
通過訪問,我們獲取到了位于碼云倉(cāng)庫(kù)中的屬性信息。
1.6 配置文件的命名規(guī)則與訪問
注意,上面案例中的配置文件的名稱,并不是隨便命名的,而是有一定的規(guī)則來約束的,具體如下:
2.編寫客戶端程序
2.1 創(chuàng)建項(xiàng)目
創(chuàng)建一個(gè)SpringCloud項(xiàng)目
2.2 pom文件修改
配置中心的客戶端使用的依賴需要注意,不是config-server了,具體如下:
<project?xmlns="http://maven.apache.org/POM/4.0.0"?xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
?xsi:schemaLocation="http://maven.apache.org/POM/4.0.0?http://maven.apache.org/xsd/maven-4.0.0.xsd">
?<modelVersion>4.0.0modelVersion>
?<parent>
??<groupId>org.springframework.bootgroupId>
??<artifactId>spring-boot-starter-parentartifactId>
??<version>1.5.13.RELEASEversion>
?parent>
?<groupId>com.bobogroupId>
?<artifactId>config-clientartifactId>
?<version>0.0.1-SNAPSHOTversion>
?<dependencyManagement>
??<dependencies>
???<dependency>
????<groupId>org.springframework.cloudgroupId>
????<artifactId>spring-cloud-dependenciesartifactId>
????<version>Dalston.SR5version>
????<type>pomtype>
????<scope>importscope>
???dependency>
??dependencies>
?dependencyManagement>
?<dependencies>
??<dependency>
???<groupId>org.springframework.bootgroupId>
???<artifactId>spring-boot-starter-webartifactId>
??dependency>
??<dependency>
???<groupId>org.springframework.cloudgroupId>
???<artifactId>spring-cloud-starter-eurekaartifactId>
??dependency>
??<dependency>
???<groupId>org.springframework.cloudgroupId>
???<artifactId>spring-cloud-starter-configartifactId>
??dependency>
?dependencies>
?<build>
??<plugins>
???<plugin>
????<groupId>org.springframework.bootgroupId>
????<artifactId>spring-boot-maven-pluginartifactId>
???plugin>
??plugins>
?build>
project>
123456789101112131415161718192021222324252627282930313233343536373839404142434445
2.3 修改配置文件
注意在配置中心的客戶端服務(wù)中,配置文件的名稱必須是bootstrap.properties或者bootstrap.yml文件。官方解釋:
“Spring Cloud 構(gòu)建于 Spring Boot 之上,在 Spring Boot 中有兩種上下文,一種是 bootstrap, 另外一種是 application, bootstrap 是應(yīng)用程序的父上下文,也就是說 bootstrap 加載優(yōu)先于 applicaton。bootstrap 主要用于從額外的資源來加載配置信息,還可以在本地外部配置文件中解密屬性。這兩個(gè)上下文共用一個(gè)環(huán)境,它是任何Spring應(yīng)用程序的外部屬性的來源。bootstrap 里面的屬性會(huì)優(yōu)先加載,它們默認(rèn)也不能被本地相同配置覆蓋。
”
spring.application.name=config-client
server.port=9051
#設(shè)置服務(wù)注冊(cè)中心地址,指向另一個(gè)注冊(cè)中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/
#默認(rèn)?false,這里設(shè)置?true,表示開啟讀取配置中心的配置
spring.cloud.config.discovery.enabled=true
#對(duì)應(yīng)?eureka?中的配置中心?serviceId,默認(rèn)是?configserver
spring.cloud.config.discovery.serviceId=config-server
#指定環(huán)境
spring.cloud.config.profile=dev
#git?標(biāo)簽
spring.cloud.config.label=master
12345678910111213
2.4 修改啟動(dòng)類
@SpringBootApplication
@EnableEurekaClient
public?class?ConfigClientStart?{
?public?static?void?main(String[]?args)?{
??SpringApplication.run(ConfigClientStart.class,?args);
?}
}
12345678
2.5 創(chuàng)建控制器
在控制中我們嘗試獲取配置中心的數(shù)據(jù),具體如下:
@RestController
public?class?ShowController?{
?
?@Value("${e-book}")
?private?String?msg;
?
?@RequestMapping("/showMsg")
?public?String?showMsg(){
??return?msg;
?}
}
1234567891011
2.6 啟動(dòng)測(cè)試
訪問:http://localhost:9051/showMsg
好文章,我在看


















