springcloud學習之路: (五) springcloud集成SpringCloudConfig分布式配置中心


SpringCloud全家桶中的分布式配置中心SpringCloudConfig, 它使用git來管理配置文件, 在修改配置文件后只需要調用一個接口就可以讓新配置生效, 非常方便.

SpringCloudConfig分為兩部分, 服務端和客戶端, 服務端是用來提供配置文件信息的, 而客戶端是用來使用配置文件信息的, 我們接下來就開始集成.

一、SpringCloudConfig服務端

1. 新建一個Module

 2. 選擇springboot工程

 3. 起個名字

 4. 選擇配置中心服務端

5.  選擇注冊中心客戶端

 6. 配置application.properties文件

# 服務端口 server.port = 8088 # 填寫注冊中心服務器地址 eureka.client.service-url.defaultZone = http://localhost:8081/eureka
# 注冊配置中心別名 spring.application.name = service-config # 配置存儲地址(git) spring.cloud.config.server.git.uri = https://gitee.com/XXX/spring-cloud-config
# 存儲文件夾 spring.cloud.config.server.git.search-paths = myconfig # git主分支 spring.cloud.config.label = master

7. 配置service-config啟動文件

// 開啟注冊中心客戶端
@EnableEurekaClient // 開啟配置中心服務器
@EnableConfigServer

 

二、git倉操作

1. 新建git倉

 填寫信息

 2. 新建文件夾

 命名文件夾

 3. 新建文件

 寫入信息

文件的命名是有規范的, [服務名稱-環境. properties]否則你的服務器無法讀取配置文件, 我們來查看一下service-a的配置文件名稱

 所以我們的配置文件應該叫

service-objcat-a-dev. properties

 

三、啟動服務訪問

 http://localhost:8088/service-objcat-a-dev.properties

 http://localhost:8088/service-objcat-a-dis.yml

 運行無問題

 

四、SpringCloudConfig服務端

service-a開啟分布式配置服務

1. 首先在service-a的pom中添加依賴

<!-- 分布式配置中心客戶端依賴 -->
<dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-config-client</artifactId>
</dependency>

2. 修改配置文件

application.yml修改成bootstrap.yml這里說一下, 這兩個名字都是應用的配置文件, 但是bootstrap.yml會先執行, 其次是配置分布式配置中心服務器的規范就是在bootstrap.yml中配置的, 這倆個配置文件可以共存, 這里為了方便起見, 所以直接就改名了, 我們繼續

# 分布式配置中心 cloud: config: profile: dev discovery: enabled: true service-id: service-config

注意別名一定要跟你上面配置服務器的名稱一致, profile千萬不要亂寫, 寫你需要應用配置文件的環境, 還記得我們的配置文件命名方式嗎 [服務名-環境.yml]

3. 到這里已經配置完成了, 我們來寫個接口驗證一下吧!

@Value("${name}") private String name; @RequestMapping("/hello") public String hello() { return name; }

@value就是從配置文件中讀取一個字段, 我們name這個字段是存在服務端的, 所以如果可以讀取出來, 就證明分布式配置中心是可以用的, 之后我們來運行一下服務

 訪問接口

http://localhost:8082/hello

4. 動態更改

現在我們的配置文件還不能做到遠程動態更改, 我們接下來要做的就是線上刷新字段, 不需要重啟服務器, 我們首先給service-a導入監控模塊的包

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

5. 修改配置文件, 在配置文件中增加如下字段 暴露所有endpoints

management:
  endpoints:
    web:
      exposure:
        include: "*"

6. 在控制器中配置刷新注解@RefreshScope, 只有配置過刷新注解的控制器中的值才會被刷新.

 7. 重啟服務

 8. 修改git上的配置信息

 9. 再次訪問, 發現沒有任何變化

 10. 這里需要調用一個刷新接口即可, 注意一定要使用post請求, 可以使用命令行或者postman.

命令行: 

curl -X POST http://localhost:8082/actuator/refresh

postman: 

http://localhost:8082/actuator/refresh

 11. 再次訪問接口, 成功

 文中案例下載


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM