SpringBoot 整合 Dubbo + Zookpeer 错误

早些年在公司一直用 Dubbo + Zookpeer 这一套的微服务,不过一套架构全部封装得很深,没有认真探究这一套微服务的玩法。后来的工作中一直用的是 SpringCloud 或者 SpringCloudAlibaba,以至于都忘记 Dubbo 这套微服务的玩法了。

最近开始探究这一块的知识,自己搭建了一套 SpringBoot 整合 Dubbo + Zookpeer 的项目。由于本人的各种中间件都是在虚拟机上,Windows 上没有一个服务,这也导致项目整合的时候一直启动失败。

经过两天的排查与百度,终于解决了这个问题,这里记录一下。

项目配置如下:

server.port=8081

dubbo.application.name=consumer
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880

dubbo.registry.address=zookeeper://192.168.222.100:2181

项目在启动的过程中,日志一直出现这个信息:

Default schema


Starting Initiating client connection, connectString=192.168.222.100:2181 sessionTimeout=60000 watcher=org.apache.curator.ConnectionState@4ed9f7b1

Socket connection established to 192.168.222.100/192.168.222.100:2181, initiating session


Session establishment complete on server 192.168.222.100/192.168.222.100:2181, sessionid = 0x100001f69fa000a, negotiated timeout = 40000

 最后报错信息如下:

java.lang.RuntimeException: Can not create registry service-discovery-registry://192.168.222.100:2181/org.apache.dubbo.registry.RegistryService?application=consumer&dubbo=2.0.2&interface=org.apache.dubbo.registry.

RegistryService&pid=15088&qos.enable=false&registry=zookeeper

&release=3.0.7&timeout=250000

重点在这一局:Can not create registry service-discovery-registry

翻译过来就是:无法创建  服务发现注册 注册中心

 刚开始怀疑是 Docker 安装的 Zookeeper 有问题,后来登陆 Zookpeer 容器查看日志,发现了 Zookpeer 启动成功的日志:Welcome to ZooKeeper!

这说明 Zookpeer 没问题,难道是 IP 有问题?将配置文件的注册中心地址的 IP 改成 localhost 直接报错:

 Socket error occurred: localhost/0:0:0:0:0:0:0:1:2181: Connection refused: no further information


 Opening socket connection to server localhost/0:0:0:0:0:0:0:1:2181. Will not attempt to authenticate using SASL (unknown error)

。。。。。。

Application run failed

java.lang.IllegalStateException: java.lang.IllegalStateException: zookeeper not connected

这说明改成 localhost 或者 127.0.0.1 都是不行的。

经过两天的排查与百度,找到了一篇文章,作者也是历经艰辛才解决了这个问题。我们使用别人的劳动成果,这里贴出文章出处:

springboot整合dubbo时连接zookeeper——天坑

作者通过 Debug 源码的方式解决了问题,同时这篇文章也被华为开发者联盟收录。

作者遇到的两个问题,我们也遇到了。

在我们这里,第一个是因为我们填写配置文件的 IP 不对。

第二个一直没有解决,直到我们百度到这篇文章。

后面经过多次尝试,将这两个新加的参数的值修改为50秒,也就是50000是可以成功的。

最后贴出完整的参数配置:

server.port=8081

dubbo.application.name=consumer
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880

dubbo.registry.address=zookeeper://192.168.222.100:2181
# 新加的参数
dubbo.registry.timeout=50000
# 新加的参数
dubbo.registry.parameters.blockUntilConnectedWait=50
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北冥牧之

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值