SpringCloud
全家桶中的分布式配置中心SpringCloudConfig
, 它使用git
来管理配置文件, 在修改配置文件后只须要调用一个接口就可让新配置生效, 很是方便.git
SpringCloudConfig分为两部分, 服务端和客户端, 服务端是用来提供
配置文件信息的, 而客户端是用来使用
配置文件信息的, 咱们接下来就开始集成.web
1. 新建一个Module
spring
2. 选择springboot工程bootstrap
3. 起个名字springboot
4. 选择配置中心服务端服务器
5. 选择注册中心客户端app
6. 配置application.properties文件curl
# 服务端口 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
1. 新建git仓spring-boot
填写信息
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
运行无问题
给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
这个字段是存在服务端的, 因此若是能够读取出来, 就证实分布式配置中心是能够用的, 以后咱们来运行一下服务
访问接口
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. 再次访问接口, 成功