项目构建
演示项目基于SpringBoot 2.3.3.RELEASE
项目依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-config</artifactId>
<version>2.2.4.RELEASE</version>
</dependency>
bootstrap.yml配置
新建bootstrap.yml文件写入配置:
spring:
application:
name: zk-config #
profiles:
active: dev
cloud:
zookeeper:
connect-string: 127.0.0.1:2181
config:
enabled: true
root: /config
default-context: apps
profile-separator: '::'
其中config下配置参数含义:
- enabled: 设置为true表示zookeeper config可用
- root: 表示以/config为根节点查找其子节点作为配置文件,子节点名默认为应用名(zk-config),若应用名未配置则使用default-context属性的值(此处为apps,默认为application)作为子节点名
- default-context: 设置所有应用程序使用的名称
- profile-separator: 设置文件分隔符,该分隔符用于在带有配置文件的属性源中分隔配置文件名称,意思就是读取zookeeper中配置文件是会在/config根节点下读取zk-config::dev节点(dev为profiles.active值)
控制层编写
@RefreshScope
@RestController
@RequestMapping("/")
public class ZkController {
@Value("${param}")
private boolean param;
@GetMapping("/get")
public String get(){
if(param){
return "true";
}
else {
return "false";
}
}
}
param是boolean型的变量,其值会从zookeeper中读取,get()是一个对外接口,可获取param当前值,@RefreshScope可在zookeeper中配置改变时,应用中的变量也一起改变。
定义项目配置
通过zkui等zookeeper可视化工具向zookeeper中写入配置:
param节点是用来测试的参数,server.port表示该SpringBoot应用启动的端口。
测试
启动服务,访问接口:
能通过zookeeper中定义的9000端口启动服务并返回param的值说明通过zookeeper作为配置中心基本可行。