美文网首页
使用Dubbo趟过的坑

使用Dubbo趟过的坑

作者: Crazy_Coder | 来源:发表于2017-03-31 15:14 被阅读0次

最近在做一个项目,这个项目里有两个系统。这是背景!

这两个系统不能互相访问!这是坑爹的需求!

然后我不想使用数据库共享,也不希望用rest的方式,所以我想到了用dubbo来解决!这是我的解决方案!

项目A的配置(服务提供者)

<!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:application name="projectA"/>

<!-- 用dubbo协议暴露服务 -->
<dubbo:protocol name="rmi" port="20881"/>

<!-- 使用暴露服务地址 -->
<dubbo:registry id="projectARegistry" address="zookeeper://192.168.72.232:2181"/>

<!-- 注册服务 -->
<dubbo:service interface="com.company.demo.service.DemoService" ref="demoServiceImpl" registry="projectARegistry"/>

项目B的配置(服务消费者)

<dubbo:application name="projectB"/>

<dubbo:registry address="zookeeper://192.168.72.232:2181"/>

<dubbo:registry id="projectARegistry" address="zookeeper://192.168.72.232:2181"/>

<!-- DemoService获取 -->
<dubbo:reference interface="com.company.demo.service.DemoService" id="demoServiceImpl" registry="projectARegistry"/>

发现错误!

坑爹的错误马上就要出现了!

[http-bio-8080-exec-7] WARN o.s.remoting.rmi.RmiProxyFactoryBean- Could not connect to RMI service [rmi://192.168.72.235:20881/com.company.demo.service.DemoService] - retrying

我找了很久很久,终于在一个很不起眼的地方发现了一段代码。

Caused by: org.springframework.remoting.RemoteConnectFailureException: Could not connect to remote service [rmi://192.168.72.235:20881/com.ztesoft.zsmartcity.ynzw.demo.service.DemoService]; nested exception is java.rmi.ConnectException: Connection refused to host: 127.0.0.1; nested exception is: 
        java.net.ConnectException: 拒绝连接
        at org.springframework.remoting.rmi.RmiClientInterceptorUtils.convertRmiAccessException(RmiClientInterceptorUtils.java:150)
        at org.springframework.remoting.rmi.RmiClientInterceptor.doInvoke(RmiClientInterceptor.java:348)
        at org.springframework.remoting.rmi.RmiClientInterceptor.refreshAndRetry(RmiClientInterceptor.java:331)
        at org.springframework.remoting.rmi.RmiClientInterceptor.handleRemoteConnectFailure(RmiClientInterceptor.java:307)
        at org.springframework.remoting.rmi.RmiClientInterceptor.invoke(RmiClientInterceptor.java:263)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
        at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:213)
        at com.sun.proxy.$Proxy64.list(Unknown Source)
        at com.alibaba.dubbo.common.bytecode.Wrapper0.invokeMethod(Wrapper0.java)
        at com.alibaba.dubbo.rpc.proxy.javassist.JavassistProxyFactory$1.doInvoke(JavassistProxyFactory.java:46)
        at com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker.invoke(AbstractProxyInvoker.java:72)
        at com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol$2.doInvoke(AbstractProxyProtocol.java:93)
        at com.alibaba.dubbo.rpc.protocol.AbstractInvoker.invoke(AbstractInvoker.java:144)
        at com.alibaba.dubbo.rpc.listener.ListenerInvokerWrapper.invoke(ListenerInvokerWrapper.java:74)
        at com.alibaba.dubbo.rpc.protocol.dubbo.filter.FutureFilter.invoke(FutureFilter.java:53)
        at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)
        at com.ztesoft.zsmart.pot.dubbo.filter.ConsumerTraceFilter.invoke(ConsumerTraceFilter.java:36)
        at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)
        at com.alibaba.dubbo.monitor.support.MonitorFilter.invoke(MonitorFilter.java:74)
        at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)
        at com.alibaba.dubbo.rpc.filter.ConsumerContextFilter.invoke(ConsumerContextFilter.java:48)
        at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)
        at com.alibaba.dubbo.rpc.protocol.InvokerWrapper.invoke(InvokerWrapper.java:53)
        at com.alibaba.dubbo.rpc.cluster.support.FailoverClusterInvoker.doInvoke(FailoverClusterInvoker.java:77)
        ... 74 more

我特么什么时候写了127.0.0.1这个地址的,我擦嘞!!!而且明明获取的是rmi://192.168.72.235:20881/com.company.demo.service.DemoService这个啊。

尝试解决问题

遇到这种叼问题第一个想到的就是debug

我先是在服务注册的地方,讲协议格式改成:

<dubbo:protocol name="rmi" port="20881" host="192.168.72.235"/>
192.168.72.235是服务提供者所在服务器的ip
  1. 配置服务器上的debug端口
  2. 在idea中配置debug远程tomcat
  3. 开始debug

他妈的,发现dubbo在某一个位置,讲我的url的ip给改了,如下:

private void exportLocal(URL url) {
    if (!Constants.LOCAL_PROTOCOL.equalsIgnoreCase(url.getProtocol())) {
        // 他娘的,设置成127.0.0.1了
        URL local = URL.valueOf(url.toFullString()).setProtocol(Constants.LOCAL_PROTOCOL).setHost(NetUtils.LOCALHOST).setPort(0);
        // rest
        ServiceImplHolder.getInstance().pushServiceImpl(ref);
        // rest end
        Exporter<?> exporter = protocol.export(proxyFactory.getInvoker(ref, (Class) interfaceClass, local));
        exporters.add(exporter);
        logger.info("Export dubbo service " + interfaceClass.getName() + " to local registry");
    }
}

好了,没办法,搞不定,总不能去改dubbo的代码吧。。。

然后我就用Naming去获取上面那个rmi://...

Object obj = Naming.lookup("rmi://192.168.72.235:20881/com.company.demo.service.DemoService");

发现果然被坑了,获取的类是代理出来的,里面果然有个127.0.0.1

真正开始解决问题了

  1. 在网上查,dubbo怎么去获取本机ip
  2. 翻看dubbo源码,在NetUtils中的getLocalAddress0这个方法
  3. dubbo获取本机所有网卡中的ip地址,然后拿到第一个不是127.0.0.1的那个ip
  4. 设置服务器上的hosts,vim /etc/hosts
192.168.72.235  localhost hostname

# 192.168.72.235 服务器ip
# localhost
# hostname 是主机名,在/etc/sysconfig/network进行配置

重启服务提供者服务,完美解决问题!!!

相关文章

  • 使用Dubbo趟过的坑

    最近在做一个项目,这个项目里有两个系统。这是背景! 这两个系统不能互相访问!这是坑爹的需求! 然后我不想使用数据库...

  • Dubbo中的那些坑(一)注解配置

    Dubbo注解配置的那些坑 Dubbo中实现了provider与consumer的注解配置,但其中依然有许多坑。 ...

  • jenkins使用过程趟过的3个坑

    修改用户权限<跳过认证> 将/var/lib/jenkins/config.xml文件中的如下部分删除,可跳过认证...

  • 对 zookeeper 和 dubbo 问题总结

    最近在搭建 zookeeper 和 dubbo 的环境时候,踩过很多坑,所以在此总结下! 一、zookeeper ...

  • async await 与 forEach()一起用坏的味道

    趟过的一个坑:Array.forEach与 async await一起使用,并没有达到自己预期的效果,后面查询资料...

  • 我和孩子趟过的坑

    孩子过了三岁,完成了早教,接踵而来的就是各种兴趣班。都说艺术教育影响孩子的一生,美育,美术、音乐、舞蹈、口才、各种...

  • 足彩,我所趟过的坑

    1 第一次买彩票,是听同事忽悠,比较容易赚钱,他玩的是足彩。 讲得我蠢蠢欲动,感觉自己平时对足球也比较关注,就猜赢...

  • boot集成dubbo踩过的坑

    这里只阐述如何集成生产者端,消费者端差不多雷同就不多叙述了: 1.首先映入相关依赖 2.然后配置文件 3.编写测试...

  • Dubbo源码分析(十) 网络通信

    之前我们说过,Dubbo是用Netty实现的网络通信,下面我们就来分析一下Dubbo使用Netty的具体实现。先来...

  • dubbo

    目标 掌握dubbo是什么 掌握dubbo能做什么 掌握dubbo的架构 掌握dubbo的特性 掌握dubbo使用...

网友评论

      本文标题:使用Dubbo趟过的坑

      本文链接:https://www.haomeiwen.com/subject/ivrvottx.html