SpringCloud Config使用配置方法
Config 介紹
Spring Cloud Config項目是一個解決分布式系統(tǒng)的配置管理方案。它包含了Client和Server兩個部分,server提供配置文件的存儲、以接口的形式將配置文件的內(nèi)容提供出去,client通過接口獲取數(shù)據(jù)、并依據(jù)此數(shù)據(jù)初始化自己的應(yīng)用。
構(gòu)建配置中心
配置中心服務(wù)端配置
新建一個配置中心模塊,且注冊到eureka中,在其他服務(wù)的基礎(chǔ)上增加如下配置
pom文件增加配置服務(wù)端設(shè)置
<!--config配置中⼼服務(wù)端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
配置需要增加如下配置
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作為遠程配置中心的拉取地址,否則會因為github網(wǎng)絡(luò)不暢出現(xiàn)各種問題。配置完成之后我們在啟動類加入@EnableConfigServer
@SpringBootApplication
@EnableConfigServer
@EnableDiscoveryClient
public class ConfigApplication9007 {
public static void main(String[] args) {
SpringApplication.run(ConfigApplication9007.class,args);
}
}
即完成配置中心服務(wù)端配置,通過服務(wù)端直接訪問配置文件

配置中心客戶端配置以及手動刷新
pom文件添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
配置文件重命名為bootstrap.yml之后增加對配置中心的使用。bootstrap.yml是系統(tǒng)級別的,優(yōu)先級⽐application.yml⾼,應(yīng)⽤啟動時會檢查這個配置⽂件,在這個配置⽂件中指定配置中⼼的服務(wù)地址,會⾃動拉取所有應(yīng)⽤配置并且啟⽤。配置暴露健康檢查等端點接⼝,以更新配置
spring
cloud:
config:
name: zhao-service-resume
profile: dev
label: main
uri: http://localhost:9007
management:
endpoints:
web:
exposure:
include: "*"
經(jīng)過配置之后增加配置訪問的內(nèi)容
@RestController
@RequestMapping("/config")
public class ConfigController {
// 和取本地配置信息一樣
@Value("${zhao.name}")
private String name;
// @Value("${mysql.url}")
// private String mysqlUrl;
// 內(nèi)存級別的配置信息
// 數(shù)據(jù)庫,redis配置信息
@GetMapping("/viewconfig")
public String viewconfig() {
return "zhaoname==>" + name;
}
}
訪問改獲取配置的接口

但是這樣無法獲取最新配置,我們需要在獲取配置的配置類上加入@RefreshScope注解。并且在更改后手動向使用配置文件的服務(wù)健康檢查接口發(fā)送POST請求才能更新

返回為空表示無變更數(shù)據(jù),上述為正常獲取到配置文件變更
借助Spring Cloud Bus動態(tài)刷新配置
網(wǎng)上的教程多以官方支持的Rabbitmq和kafka作為基礎(chǔ)來實現(xiàn),我這里以阿里自己的Rocketmq為例來進行操作
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-bus-rocketmq</artifactId>
<version>2.1.0.RELEASE</version>
</dependency>
在配置中心的服務(wù)端和客戶端中進行相應(yīng)的配置
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
通過訪問http://localhost:9007/actuator/bus-refresh 即可將配置改變推送到配置
到此這篇關(guān)于SpringCloud Config使用的文章就介紹到這了,更多相關(guān)SpringCloud Config內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Spring中利用@Order注解對bean和依賴進行排序
在Spring框架中,@Order是一個經(jīng)常被忽視但非常重要的注解,在項目開發(fā)中,當我們需要維護bean的特定順序或者存在許多相同類型的bean時,這個注解就發(fā)揮了作用,這篇文章講的就是如何利用@Order注解對bean和依賴進行排序,需要的朋友可以參考下2023-11-11
Springboot詳解如何實現(xiàn)SQL注入過濾器過程
這篇文章主要介紹了基于springboot實現(xiàn)SQL注入過濾器,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2022-06-06
SpringBoot整合SpringSecurity實現(xiàn)圖形驗證碼功能
圖形驗證碼是一種用于區(qū)分用戶是人類還是計算機程序的自動化測試,它通常用于防止自動化軟件進行惡意操作,如濫用在線服務(wù)、暴力破?解密碼或進行垃圾郵件發(fā)送等,下面將介紹?Spring?Boot?整合?Spring?Security?實現(xiàn)圖形驗證碼功能,需要的朋友可以參考下2024-12-12
Springcloud-nacos實現(xiàn)配置和注冊中心的方法
這篇文章主要介紹了Springcloud-nacos實現(xiàn)配置和注冊中心的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2019-07-07

