使用说明

Jdk-Plus2022年1月7日
大约 1 分钟

一个集成Zookeeper依赖的Springboot扩展

引入依赖

<dependency>
    <groupId>plus.jdk.zookeeper</groupId>
    <artifactId>spring-boot-starter-zookeeper</artifactId>
    <version>1.0.1</version>
</dependency>

需要添加的配置项

# 是否开启该组件
plus.jdk.zookeeper.enabled=true
# 指定zookeeper集群列表
plus.jdk.zookeeper.hosts=127.0.0.1:2181,127.0.0.2:2181
# 连接超时时间
plus.jdk.zookeeper.conn-timeout=3000
# 每个节点数据多久更新一次
plus.jdk.zookeeper.heart-rate=30
# 会话超时时间
plus.jdk.zookeeper.session-timeout=3000
# 处理节点数据变化事件(节点删除、节点新增、节点修改)的核心线程数,默认10个
plus.jdk.zookeeper.watcher-thread-core-poll-size=10
# 指定一个用于数据序列化的实现类
plus.jdk.zookeeper.data-adapter=plus.jdk.zookeeper.client.DefaultZKDataAdapter

引入后如何使用

当上文配置完成后,您只需要在对应的bean实例中使用 @ZookeeperNode 注解来指定要获取哪个节点的数据即可,示例如下:

import org.springframework.stereotype.Component;
import plus.jdk.grpc.client.INameResolverConfigurer;
import plus.jdk.grpc.model.GrpcNameResolverModel;
import plus.jdk.zookeeper.annotation.ZookeeperNode;

import java.net.URI;
import java.util.ArrayList;
import java.util.List;

@Component
public class GrpcGlobalNameResolverConfigurer implements INameResolverConfigurer {


    private final RSACipherService rsaCipherService;


    @ZookeeperNode(value = "/brand/grpc/name/provider", adapter = DefaultZKDataAdapter.class)
    private List<GrpcNameResolverModel> grpcNameResolverModels;

}
Loading...