Config 介绍
Spring Cloud Config项目是一个解决分布式系统的配置管理方案。它包含了Client和Server两个部分,server提供配置文件的存储、以接口的形式将配置文件的内容提供出去,client通过接口获取数据、并依据此数据初始化自己的应用。
构建配置中心
配置中心服务端配置
新建一个配置中心模块,且注册到eureka中,在其他服务的基础上增加如下配置
pom文件增加配置服务端设置
1
2
3
4
5
|
<!--config配置中⼼服务端--> <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作为远程配置中心的拉取地址,否则会因为github网络不畅出现各种问题。配置完成之后我们在启动类加入@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); } } |
即完成配置中心服务端配置,通过服务端直接访问配置文件
配置中心客户端配置以及手动刷新
pom文件添加
1
2
3
4
|
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-client</artifactId> </dependency> |
配置文件重命名为bootstrap.yml之后增加对配置中心的使用。bootstrap.yml是系统级别的,优先级⽐application.yml⾼,应⽤启动时会检查这个配置⽂件,在这个配置⽂件中指定配置中⼼的服务地址,会⾃动拉取所有应⽤配置并且启⽤。配置暴露健康检查等端点接口,以更新配置
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: "*" |
经过配置之后增加配置访问的内容
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; // 内存级别的配置信息 // 数据库,redis配置信息 @GetMapping ( "/viewconfig" ) public String viewconfig() { return "zhaoname==>" + name; } } |
访问改获取配置的接口
但是这样无法获取最新配置,我们需要在获取配置的配置类上加入@RefreshScope注解。并且在更改后手动向使用配置文件的服务健康检查接口发送POST请求才能更新
返回为空表示无变更数据,上述为正常获取到配置文件变更
借助Spring Cloud Bus动态刷新配置
网上的教程多以官方支持的Rabbitmq和kafka作为基础来实现,我这里以阿里自己的Rocketmq为例来进行操作
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> |
在配置中心的服务端和客户端中进行相应的配置
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 |
通过访问http://localhost:9007/actuator/bus-refresh 即可将配置改变推送到配置
到此这篇关于SpringCloud Config使用的文章就介绍到这了,更多相关SpringCloud Config内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://www.cnblogs.com/zhendiao/p/15023620.html