SpringBoot 整合 Dubbo + Zookpeer 错误
早些年在公司一直用 Dubbo + Zookpeer 这一套的微服务,不过一套架构全部封装得很深,没有认真探究这一套微服务的玩法。后来的工作中一直用的是 SpringCloud 或者 SpringCloudAlibaba,以至于都忘记 Dubbo 这套微服务的玩法了。由于本人的各种中间件都是在虚拟机上,Windows 上没有一个服务,这也导致项目整合的时候一直启动失败。后面经过多次尝试,将这两个新
早些年在公司一直用 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@4ed9f7b1Socket 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®istry=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
更多推荐
所有评论(0)