使用Zookeeper作为微服务配置中心

项目构建

演示项目基于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作为配置中心基本可行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值