• (转)dubbo远程调用细节


    作者: 白文志 (来自开源社区)

    服务提供者暴露一个服务的详细过程

    上图是服务提供者暴露服务的主过程:
    首先ServiceConfig类拿到对外提供服务的实际类ref(如:HelloWorldImpl),然后通过ProxyFactory类的getInvoker方法使用ref生成一个AbstractProxyInvoker实例,到这一步就完成具体服务到Invoker的转化。

    接下来就是Invoker转换到Exporter的过程。

    Dubbo处理服务暴露的关键就在Invoker转换到Exporter的过程(如上图中的红色部分),下面我们以Dubbo和RMI这两种典型协议的实现来进行说明:

    Dubbo的实现

    Dubbo协议的Invoker转为Exporter发生在DubboProtocol类的export方法,它主要是打开socket侦听服务,并接收客户端发来的各种请求,通讯细节由Dubbo自己实现。

    RMI的实现

    RMI协议的Invoker转为Exporter发生在RmiProtocol类的export方法,
    它通过Spring或Dubbo或JDK来实现RMI服务,通讯细节这一块由JDK底层来实现,这就省了不少工作量。

    服务消费者消费一个服务的详细过程

     

    上图是服务消费的主过程:
    首先ReferenceConfig类的init方法调用Protocol的refer方法生成Invoker实例(如上图中的红色部分),这是服务消费的关键。

    接下来把Invoker转换为客户端需要的接口(如:HelloWorld)。
    关于每种协议如RMI/Dubbo/Web service等它们在调用refer方法生成Invoker实例的细节和上一章节所描述的类似。

     

    满眼都是Invoker

    由于Invoker是Dubbo领域模型中非常重要的一个概念,很多设计思路都是向它靠拢。这就使得Invoker渗透在整个实现代码里,对于刚开始接触Dubbo的人,确实容易给搞混了。
    下面我们用一个精简的图来说明最重要的两种Invoker:服务提供Invoker和服务消费Invoker:

    为了更好的解释上面这张图,我们结合服务消费和提供者的代码示例来进行说明:

    服务消费者代码
    复制代码
    public class DemoClientAction {
     
        private DemoService demoService;
     
        public void setDemoService(DemoService demoService) {
            this.demoService = demoService;
        }
     
        public void start() {
            String hello = demoService.sayHello("world" + i);
        }
    }
    复制代码

    上面代码中的’DemoService’就是上图中服务消费端的proxy,

    用户代码通过这个proxy调用其对应的Invoker(DubboInvoker、 HessianRpcInvoker、 InjvmInvoker、 RmiInvoker、 WebServiceInvoker中的任何一个),

    而该Invoker实现了真正的远程服务调用。

    服务提供者代码
    复制代码
    public class DemoServiceImpl implements DemoService {
     
        public String sayHello(String name) throws RemoteException {
            return "Hello " + name;
        }
     
    }
    复制代码

    上面这个类会被封装成为一个AbstractProxyInvoker实例,并新生成一个
    Exporter实例。这样当网络通讯层收到一个请求后,会找到对应的Exporter实例,并调用它所对应的AbstractProxyInvoker实例,从而真正调用了服务提供者的代码。
    Dubbo里还有一些其他的Invoker类,但上面两种是最重要的。

  • 相关阅读:
    linux常用的一些访问目录
    专业术语
    java基础知识回顾之javaIO类--File类应用:获取指定目录下面的指定扩展名的文件,将文件的绝对路径写入到目的文件当中
    java基础知识回顾之javaIO类--File类应用:删除带内容的目录
    java基础知识回顾之javaIO类--File类应用:过滤器接口FilenameFilter和FileFilter
    java基础知识回顾之javaIO类--File类应用:递归深度遍历文件
    java基础知识回顾之javaIO类--File类
    java基础知识回顾之java集合类-Properties集合
    java基础知识回顾之---java StringBuffer,Stringbuilder与String的区别
    java基础知识回顾之---java StringBuilder与StringBuffer异同点
  • 原文地址:https://www.cnblogs.com/xingzc/p/9140067.html
Copyright © 2020-2023  润新知