Config 介紹
Spring Cloud Config項(xiàng)目是一個(gè)解決分布式系統(tǒng)的配置管理方案。它包含了Client和Server兩個(gè)部分,server提供配置文件的存儲(chǔ)、以接口的形式將配置文件的內(nèi)容提供出去,client通過(guò)接口獲取數(shù)據(jù)、并依據(jù)此數(shù)據(jù)初始化自己的應(yīng)用。
構(gòu)建配置中心
配置中心服務(wù)端配置
新建一個(gè)配置中心模塊,且注冊(cè)到eureka中,在其他服務(wù)的基礎(chǔ)上增加如下配置
pom文件增加配置服務(wù)端設(shè)置
1
2
3
4
5
|
<!--config配置中?服務(wù)端--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-server</artifactId> </dependency> |
配置需要增加如下配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
spring: application: name: zhao-service-config cloud: config: server: git: username: xxx @qq .com password: xxx search-paths: - zhao-config-repo uri: https: //gitee.com/kylezhen/zhao-config-repo.git label: main management: endpoints: web: exposure: include: "*" endpoint: health: show-details: always |
需要注意的是我們盡量還是使用gitee作為遠(yuǎn)程配置中心的拉取地址,否則會(huì)因?yàn)間ithub網(wǎng)絡(luò)不暢出現(xiàn)各種問(wèn)題。配置完成之后我們?cè)趩?dòng)類(lèi)加入@EnableConfigServer
1
2
3
4
5
6
7
8
|
@SpringBootApplication @EnableConfigServer @EnableDiscoveryClient public class ConfigApplication9007 { public static void main(String[] args) { SpringApplication.run(ConfigApplication9007. class ,args); } } |
即完成配置中心服務(wù)端配置,通過(guò)服務(wù)端直接訪問(wèn)配置文件
配置中心客戶(hù)端配置以及手動(dòng)刷新
pom文件添加
1
2
3
4
|
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-client</artifactId> </dependency> |
配置文件重命名為bootstrap.yml之后增加對(duì)配置中心的使用。bootstrap.yml是系統(tǒng)級(jí)別的,優(yōu)先級(jí)?application.yml?,應(yīng)?啟動(dòng)時(shí)會(huì)檢查這個(gè)配置?件,在這個(gè)配置?件中指定配置中?的服務(wù)地址,會(huì)?動(dòng)拉取所有應(yīng)?配置并且啟?。配置暴露健康檢查等端點(diǎn)接口,以更新配置
1
2
3
4
5
6
7
8
9
10
11
12
|
spring cloud: config: name: zhao-service-resume profile: dev label: main uri: http: //localhost:9007 management: endpoints: web: exposure: include: "*" |
經(jīng)過(guò)配置之后增加配置訪問(wèn)的內(nèi)容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
@RestController @RequestMapping ( "/config" ) public class ConfigController { // 和取本地配置信息一樣 @Value ( "${zhao.name}" ) private String name; // @Value("${mysql.url}") // private String mysqlUrl; // 內(nèi)存級(jí)別的配置信息 // 數(shù)據(jù)庫(kù),redis配置信息 @GetMapping ( "/viewconfig" ) public String viewconfig() { return "zhaoname==>" + name; } } |
訪問(wèn)改獲取配置的接口
但是這樣無(wú)法獲取最新配置,我們需要在獲取配置的配置類(lèi)上加入@RefreshScope注解。并且在更改后手動(dòng)向使用配置文件的服務(wù)健康檢查接口發(fā)送POST請(qǐng)求才能更新
返回為空表示無(wú)變更數(shù)據(jù),上述為正常獲取到配置文件變更
借助Spring Cloud Bus動(dòng)態(tài)刷新配置
網(wǎng)上的教程多以官方支持的Rabbitmq和kafka作為基礎(chǔ)來(lái)實(shí)現(xiàn),我這里以阿里自己的Rocketmq為例來(lái)進(jìn)行操作
1
2
3
4
5
|
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-bus-rocketmq</artifactId> <version> 2.1 . 0 .RELEASE</version> </dependency> |
在配置中心的服務(wù)端和客戶(hù)端中進(jìn)行相應(yīng)的配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
spring: application: name: zhao-service-config cloud: config: server: git: username: @qq .com password: xxx search-paths: - zhao-config-repo uri: https: //gitee.com/kylezhen/zhao-config-repo.git label: main bus: enabled: true rocketmq: name-server: 127.0 . 0.1 : 9876 |
通過(guò)訪問(wèn)http://localhost:9007/actuator/bus-refresh 即可將配置改變推送到配置
到此這篇關(guān)于SpringCloud Config使用的文章就介紹到這了,更多相關(guān)SpringCloud Config內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://www.cnblogs.com/zhendiao/p/15023620.html