问题复现
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不在同一台服务器时需要注意校对服务器时间