Spring Boot + Dubbo + Zookeeper 集成

1 概述

使用 zookeeper 作为注册中心,构建 dubbo 服务提供者和消费者。

2 项目环境

(1)依赖的jar包

java 复制代码
jdk 21 
dubbo  3.2.7
zookeeper 3.8.5
spring boot 3.1.5 

(2)服务注册中心

zookeeper 服务器版本 3.8.5

3 安装 zookeeper

(1)下载安装包

访问 Zookeeper 官方下载页面:Zookeeper 下载,下载 apache-zookeeper-3.8.5-bin.tar.gz.

(2)安装和配置

安装:解压上述压缩包即可。

修改配置:进入 conf 目录,复制并重命名文件 zoo_sample.cfg 为 zoo.cfg。修改 zoo.cfg 中的配置(可选),修改内容如下:

java 复制代码
dataDir=/tmp/zookeeper/data
dataLogDir=/tmp/zookeeper/log
admin.serverPort=8888

修改环境变量(可选):将 zookeeper/bin 目录添加到 Path 环境变量中,以便从cmd窗口直接执行 Zookeeper 命令。

(3)启动

在cmd窗口使用命令"zkServer.cmd"启动 zookeeper。

(4)判断是否启动成功

在cmd窗口使用命令"zkCli.cmd"启动客户端。使用命令"ls /",返回"zookeeper"即代表启动成功。

或者在cmd窗口使用 netstat 命令检查 zookeeper 端口是否被监听。有被监听到即代表启动成功。

netstat -an | findstr :2181

4 注意事项

(1)依赖的 zookeeper jar包版本尽量与 zookeeper 服务器版本一致。

5 问题

(1)依赖包版本问题。zookeeper jar包版本为 3.4.14 时,dubbo服务连接zookeeper失败

java 复制代码
2026-01-05T14:37:14.332+08:00  WARN 35896 --- [127.0.0.1:2181)] org.apache.zookeeper.ClientCnxn          : Session 0x0 for server 127.0.0.1/<unresolved>:2181, unexpected error, closing socket connection and attempting reconnect
java.lang.IllegalArgumentException: Unable to canonicalize address 127.0.0.1/<unresolved>:2181 because it's not resolvable
    at org.apache.zookeeper.SaslServerPrincipal.getServerPrincipal(SaslServerPrincipal.java:65) ~[zookeeper-3.4.14.jar:3.4.14-4c25d480e66aadd371de8bd2fd8da255ac140bcf]
    at org.apache.zookeeper.SaslServerPrincipal.getServerPrincipal(SaslServerPrincipal.java:41) ~[zookeeper-3.4.14.jar:3.4.14-4c25d480e66aadd371de8bd2fd8da255ac140bcf]
    at org.apache.zookeeper.ClientCnxn$SendThread.startConnect(ClientCnxn.java:1001) ~[zookeeper-3.4.14.jar:3.4.14-4c25d480e66aadd371de8bd2fd8da255ac140bcf]
    at org.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1060) ~[zookeeper-3.4.14.jar:3.4.14-4c25d480e66aadd371de8bd2fd8da255ac140bcf]

原因 :zookeeper jar包版本为 3.4.14 时,解析zookeeper地址出错。

在调用 java.net.InetSocketAddress.InetSocketAddressHolder#toString 时,解析出来的地址为"127.0.0.1/<unresolved>:2181"。调用的源码如下:

java 复制代码
public String toString() {

    String formatted;

    if (isUnresolved()) {
        formatted = hostname + "/<unresolved>";
    } else {
        formatted = addr.toString();
        if (addr instanceof Inet6Address) {
            int i = formatted.lastIndexOf("/");
            formatted = formatted.substring(0, i + 1)
                    + "[" + formatted.substring(i + 1) + "]";
        }
    }
    return formatted + ":" + port;
}

解决:使用版本为 3.8.5 的 zookeeper 的jar包。

6 参考文献

(1)https://cn.dubbo.apache.org/zh-cn/overview/home/

相关推荐
拽着尾巴的鱼儿3 小时前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
小江的记录本6 小时前
【JVM虚拟机】JVM调优:常用JVM参数、调优核心指标、OOM排查、GC日志分析、Arthas工具使用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
一 乐7 小时前
高校实习信息发布网站|基于Spring Boot的高校实习信息发布网站的设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·高校实习信息发布网站
han_hanker9 小时前
BeanUtils.copyProperties 和序列化的问题
java·开发语言·spring boot
西凉的悲伤9 小时前
Spring Boot 中 @Async(value = “alertThreadPool“) 是什么?为什么企业项目喜欢自定义线程池?
spring boot·多线程·async·异步
闪电悠米11 小时前
黑马点评-优惠券秒杀-05_local_lock_cluster_problem
java·spring boot·redis·缓存
小江的记录本11 小时前
【JVM虚拟机】类加载机制:类加载全流程:加载→验证→准备→解析→初始化(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·算法·安全·spring·面试
搬石头的马农12 小时前
Claude Code SpringBoot开发:从0到1搭建企业级项目的6个核心Skill
java·人工智能·spring boot·后端·ai编程
yurenpai(27届找实习中)13 小时前
redis_点评(26.附近店铺——实现附近商家功能)
数据库·spring boot·redis
愤怒的苹果ext13 小时前
Spring Boot Redis Stream队列
spring boot·redis·消息队列·stream