redis做dubbo注册中心时,主机时间和服务器时间不同导致无法找到服务

1,012 阅读1分钟

问题复现

com.alibaba.dubbo.rpc.RpcException: No provider available from registry 192.168.106.47:6379 for service cn.com.scooper.core.dsapi.service.system.IAuthService on consumer 192.168.100.54 use dubbo version 2.6.0, may be providers disabled or not registered ?
	at com.alibaba.dubbo.registry.integration.RegistryDirectory.doList(RegistryDirectory.java:572)
	at com.alibaba.dubbo.rpc.cluster.directory.AbstractDirectory.list(AbstractDirectory.java:73)
	at com.alibaba.dubbo.rpc.cluster.support.AbstractClusterInvoker.list(AbstractClusterInvoker.java:265)
	at com.alibaba.dubbo.rpc.cluster.support.AbstractClusterInvoker.invoke(AbstractClusterInvoker.java:224)
	at com.alibaba.dubbo.rpc.cluster.support.wrapper.MockClusterInvoker.invoke(MockClusterInvoker.java:70)
	at com.alibaba.dubbo.rpc.proxy.InvokerInvocationHandler.invoke(InvokerInvocationHandler.java:51)
	at com.alibaba.dubbo.common.bytecode.proxy1.login(proxy1.java)

解决方案

通过dubbo-admin可以看到provider已经正常启动并在注册中心成功注册,但是consumber每次都抛出异常提示找不到provider,一开始我的解决方法是用zookeeper代替redis做注册中心,能成功解决报错。但是由于公司项目默认用的都是redis,所以还是不得不寻找其他解决方法。后来网上看到有人说主机时间不同步会导致这个问题。调整时间后解决问题。 PS:只有当消费者服务器时间比生产者快时会出现这个问题,比生产者慢不会有这个问题;

总结

provider和consumer不在同一台服务器时需要注意校对服务器时间