SpringBoot 整合 Dubbo + Zookpeer 错误

文章讲述了作者在尝试集成SpringBoot和Dubbo+Zookeeper时遇到的启动失败问题,主要是由于注册中心连接问题。经过排查,发现是配置文件中的IP填写不正确以及需要调整`dubbo.registry.timeout`和`dubbo.registry.parameters.blockUntilConnectedWait`参数。最终,通过设置这两个参数的值为50000,成功解决了问题。
摘要由CSDN通过智能技术生成

早些年在公司一直用 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
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot是一个开源的Java框架,用于快速构建独立的、基于Spring的应用程序。它简化了Spring应用程序的配置和部署过程,并提供了许多嵌入式服务器,如Tomcat、Jetty等。Spring Boot还提供了自动配置的特性,可以根据类路径中的依赖自动配置Spring应用程序。 Dubbo是一款高性能的分布式服务框架,也是阿里巴巴开源的项目。它提供了服务治理、远程通讯和分布式调用等功能,帮助开发人员轻松构建分布式服务化的应用。 Zookeeper是一个开源的分布式协调服务,可以用于实现分布式应用程序的一致性和可靠性。它提供了一个类似于文件系统的层次化的命名空间,并允许开发人员注册、协调和共享各种资源,如配置信息、服务注册和发现等。 当使用Spring Boot结合DubboZookeeper时,可以构建一个高性能、可扩展和可靠的微服务架构。Spring Boot提供了便利的开发和部署方式,Dubbo提供了分布式服务框架的支持,而Zookeeper则提供了分布式协调服务。开发人员可以使用Spring Boot快速构建独立的微服务应用程序,使用Dubbo进行服务间的通信和管理,同时通过Zookeeper进行服务的注册和发现。这样的架构可以方便地实现微服务架构中的资源共享和服务治理等功能,大大简化了开发人员的负担。 综上所述,Spring Boot结合DubboZookeeper可以构建高效、可靠的微服务架构,并提供了便利的开发和部署方式,帮助开发人员构建高性能的分布式应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

北冥牧之

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

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

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

打赏作者

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

抵扣说明:

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

余额充值