一、简介
在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件。
在Spring Cloud中,有分布式配置中心组件spring cloud config ,它支持配置服务放在配置服务的内存中(即本地),也支持放在远程Git仓库中。
在spring cloud config 组件中,分两个角色,一是config server,二是config client。
二、配置
2.1 Spring Cloud Config Server项目
1 pom.xml中导入Config Server需要的包
1
2
3
4
|
< dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-config-server</ artifactId > </ dependency > |
2 在Application类中添加@EnableConfigServer注解
1
2
3
4
5
6
7
8
9
10
11
|
package com.sunbufu; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.config.server.EnableConfigServer; @EnableConfigServer @SpringBootApplication public class ConfigServerApplication { public static void main(String[] args) { SpringApplication.run(ConfigServerApplication. class , args); } } |
3 修改配置文件application.yml,指定本地客户端配置文件的路径
1
2
3
4
5
6
7
8
|
spring: profiles: active: native cloud: config: server: native: searchLocations: F:/conf |
4 准备客户端配置文件
client-dev.yml文件的内容:
1
2
3
4
|
server: #设置成0,表示任意未被占用的端口 port: 8081 nickName: world |
2.2 Spring Cloud Config Client项目
1 pom.xml中导入Config Client需要的包(注意,此处跟Config Server的配置不同)
1
2
3
4
|
< dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-starter-config</ artifactId > </ dependency > |
2 在src/main/resources中,新建bootstrap.yml文件
bootstrap文件会在application文件之前加载,一般是不会变的。
1
2
3
4
5
6
7
8
|
spring: application: name: client cloud: config: uri: http://127.0.0.1:8888 profile: dev label: master |
资源文件映射如下:
1
2
3
4
5
|
/{application}/{profile}[/{label}] /{application}-{profile}.yml /{label}/{application}-{profile}.yml /{application}-{profile}.properties /{label}/{application}-{profile}.properties |
3 新建HelloController用来显示读取到的配置
1
2
3
4
5
6
7
8
9
10
11
12
13
|
package com.sunbufu.controller; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @Value ( "${nickName}" ) private String nickName; @RequestMapping ( "/hello" ) public String hello() { return "hello " + nickName; } } |
三、总结
源码地址 :https://github.com/sunbufu/sunbufu-cloud
总觉的使用svn或者git不如直接修改配置文件方便,特此记录下来。
spring cloud config本地读取配置文件
1、创建maven项目,引入spring boot 起步依赖
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
<? xml version = "1.0" encoding = "UTF-8" ?> < 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 https://maven.apache.org/xsd/maven-4.0.0.xsd" > < modelVersion >4.0.0</ modelVersion > < parent > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-parent</ artifactId > < version >2.1.7.RELEASE</ version > < relativePath /> <!-- lookup parent from repository --> </ parent > < groupId >com.wxz</ groupId > < artifactId >cloud-config-demo3</ artifactId > < version >0.0.1-SNAPSHOT</ version > < name >cloud-config-demo3</ name > < description >Demo project for Spring Boot</ description > < properties > < java.version >1.8</ java.version > </ properties > < dependencies > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter</ artifactId > </ dependency > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-test</ artifactId > < scope >test</ scope > </ dependency > </ dependencies > < dependencyManagement > < dependencies > < dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-dependencies</ artifactId > < version >${spring-cloud.version}</ version > < type >pom</ type > < scope >import</ scope > </ dependency > </ dependencies > </ dependencyManagement > < build > < plugins > < plugin > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-maven-plugin</ artifactId > </ plugin > </ plugins > </ build > </ project > |
新建config-server 模块,引入依赖
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<? xml version = "1.0" encoding = "UTF-8" ?> < 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 https://maven.apache.org/xsd/maven-4.0.0.xsd" > < modelVersion >4.0.0</ modelVersion > < parent > < groupId >com.wxz</ groupId > < artifactId >cloud-config-demo3</ artifactId > < version >0.0.1-SNAPSHOT</ version > < relativePath /> <!-- lookup parent from repository --> </ parent > < groupId >com.wxz</ groupId > < artifactId >config-server</ artifactId > < version >0.0.1-SNAPSHOT</ version > < name >config-server</ name > < description >Demo project for Spring Boot</ description > < properties > < java.version >1.8</ java.version > </ properties > < dependencies > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter</ artifactId > </ dependency > < dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-config-server</ artifactId > < version >2.1.2.RELEASE</ version > </ dependency > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-test</ artifactId > < scope >test</ scope > </ dependency > </ dependencies > < build > < plugins > < plugin > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-maven-plugin</ artifactId > </ plugin > </ plugins > </ build > </ project > |
2、配置文件:
1
2
3
4
5
6
7
8
9
10
11
12
|
spring: cloud: config: server: native: search-locations: classpath:/shared profiles: active: native application: name: config-server server: port: 8769 |
在resources下新建目录shared,里面新建文件config-client-dev
1
2
3
|
server: port: 8762 foo: foo version 1 |
在启动类添加
1
|
@EnableConfigServer |
新建config-client模块
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<? xml version = "1.0" encoding = "UTF-8" ?> < 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 https://maven.apache.org/xsd/maven-4.0.0.xsd" > < modelVersion >4.0.0</ modelVersion > < parent > < groupId >com.wxz</ groupId > < artifactId >cloud-config-demo3</ artifactId > < version >0.0.1-SNAPSHOT</ version > < relativePath /> <!-- lookup parent from repository --> </ parent > < groupId >com.wxz</ groupId > < artifactId >config-client</ artifactId > < version >0.0.1-SNAPSHOT</ version > < name >config-client</ name > < description >Demo project for Spring Boot</ description > < properties > < java.version >1.8</ java.version > </ properties > < dependencies > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-web</ artifactId > </ dependency > < dependency > < groupId >org.springframework.cloud</ groupId > < artifactId >spring-cloud-starter-config</ artifactId > < version >2.1.2.RELEASE</ version > </ dependency > < dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-test</ artifactId > < scope >test</ scope > </ dependency > </ dependencies > < build > < plugins > < plugin > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-maven-plugin</ artifactId > </ plugin > </ plugins > </ build > </ project > |
新建配置文件bootstrap.yml(bootstrap比application具有优先的读取顺序)
1
2
3
4
5
6
7
8
9
|
spring: cloud: config: uri: http://localhost:8769 fail-fast: true application: name: config-client profiles: active: dev |
新建一个controller进行测试:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package com.wxz.configclient.controller; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; /** * @author Wangxingze * @date 2019-08-26 12:58 */ @RestController public class Test { @Value ( "${foo}" ) public String foo; @GetMapping ( "/t" ) public String t(){ return foo; } } |
依次启动server client,启动时可以看到读取了配置文件和启动黛安克,访问:
注意:spring boot 和cloud的版本以及config依赖的版本
1
2
3
4
|
< groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-parent</ artifactId > < version >2.1.7.RELEASE</ version > < relativePath /> <!-- lookup parent from repository --> |
我这里好像没有指定spring cloud 的版本呀
config的相关依赖使用:<version>2.1.2.RELEASE</version>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/sunbufu/article/details/79291746