因为某些漏洞,需要修复,所以要求将dubbo版本从2.7.7升级到2.7.18以上。原以为只改一下版本号就可以兼容,没想到过程中出了很多奇奇怪怪的问题。
问题一
provider改成2.7.18,consumer也改成了2.7.18。但是consumer死活启动不了,日志上报错dubbo接口的类bean找不到,所以APPLICATION FAILED TO START。但是去zk上看,看得到provider的注册信息,所有注册上的信息也都是正确的,但就是连接不上,最后,替换了@DubboReference注解里的一个属性就好了。
之前我使用的是@DubboReference(registry= "consumer1", version = "0.0.1")
,因为是多个dubbo引用,所以用了多配置。这次升级后好像就不行了,改成了@DubboReference(application = "consumer1", version = "0.0.1")
就能启动了。。。
奇怪得很,registry替换为application就好了。。。而且有些项目没替换也能启动,就这一个项目有问题。。。无解
问题二
provider启动后,注册中心上的provider的IP是虚拟IP,不是屋里ip,consumer启动会不停重试,同时打印org.apache.dubbo.remoting.exchange.support.header.ReconnectTimerTask
报错日志,
之后发现dubbo在2.7.14的更新中改了获取ip的方法,如果你部署的机器上有多个网卡,就会用第一个符合地址要求的ip地址来作为注册信息,分析
分析2
最后只能在dockerFile里加了启动命令,手动强制指定了绑定ip,但是这样做的后果就是无法集群部署,多个实例的时候就没办法了。。。