3.Dubbo服务调用过程

作者: 飞翔的鲲 | 来源:发表于2018-02-22 21:45 被阅读883次

dubbo 请求调用过程分析
http://blog.csdn.net/paul_wei2008/article/details/70076898

Dubbo服务总体过程


image.png

服务端暴露服务过程


image.png

客户端服务订阅、通知总览


  1. 客户端订阅服务,调subscribe(),主要通过zkClient与注册中心zookeeper交互,将监听器NotifyListener 注入zkClient,这样注册中心就可以在服务目录变更情况下通知客户端更新目录。调用notify()进行更新。

参考
dubbo作为消费者注册过程分析

image.png image.png
  • 监听器RegistryDirectory
public class RegistryDirectory<T> extends AbstractDirectory<T> implements NotifyListener {
   //订阅方法
    public void subscribe(URL url) {
        this.setConsumerUrl(url);
        this.registry.subscribe(url, this);
    }
    //通知方法
    public synchronized void notify(List<URL> urls) {

之前订阅了通知服务,现在目录更新通知客户端更新服务列表缓存。

ZookeeperRegistry:负责与zookeeper进行交互
RegistryProtocol:从注册中心获取可用服务,或者将服务注册到zookeeper,然后提供服务或者提供调用代理。
RegistryDirectory:维护着所有可用的远程Invoker或者本地的Invoker。这个类实现了NotifyListner。
NotifyListener:负责RegistryDirectory和ZookeeperRegistry的通信。
FailbackRegistry:继承自Registry,实现了失败重试机制。

客户端订阅服务


image.png

主要调注册中心订阅服务,设置监听器,同时获取服务列表缓存到客户端。

客户端请求服务过程


image.png image.png
1.      将方法名方法参数传入InvokerInvocationHandler的invoke方


对于Object中的方法toString, hashCode, equals直接调用invoker的对应方法,


这里对于Object的方法需要被远程调用吗?调用了是不是报错比默认处理更好呢??


远程调用层是以Invocation, Result为中心, 这里根据要调用的方法以及传入的参数构建RpcInvocation对象,作为Invoker的入参


2.      MockClusterInvoker根据参数提供了三种调用策略


不需要mock, 直接调用FailoverClusterInvoker


强制mock,调用mock


先调FailoverClusterInvoker,调用失败在mock、


3.      FailoverClusterInvoker默认调用策略


通过目录服务查找到所有订阅的服务提供者的Invoker对象


路由服务根据策略来过滤选择调用的Invokers


通过负载均衡策略LoadBalance来选择一个Invoker


4.      执行选择的Invoker.inoker(invocation)


经过监听器链,默认没有


经过过滤器链,内置实现了很多


执行到远程调用的DubboInvoker


5.      DubboInvoker


根据url 也就是根据服务提供者的长连接,这里封装成交互层对象ExchangeClient供这里调用


判断远程调用类型同步,异步还是oneway模式


ExchangeClient发起远程调用,底层remoting不在这里描述了


获取调用结果:


        Oneway返回空RpcResult


        异步,直接返回空RpcResult, ResponseFuture回调


        同步, ResponseFuture模式同步转异步,等待响应返回

服务接收请求过程


image.png image.png
DubboProtocol的requestHandler是ExchangeHandler的实现,是remoting层接收数据后的回调。


requestHandler.replay方法接收请求消息,这里只处理远程调用消息Invocation。


1.      通过Invocation获取服务名和端口组成serviceKey=com.alibaba.dubbo.demo.DemoService:20880, 从DubboProtocol的exproterMap中获取暴露服务的DubboExporter, 在从dubboExporter 获取invoker返回


2.      经过过滤器链


3.      经过监听器链


4.      到达执行真正调用的invoker, 这个invoker由代理工厂ProxyFactory.getInvoker(demoService, DemoService.class, registryUrl)创建,具体请看代理那部分介绍。


调用demoService实例方法,将结果封装成RpcResult返回


5.      交换层构建Response,通过Remoting层编码传输将结果响应给调用方

服务消费方发起远程调用的底层通信


image.png

服务提供方接收请求并响应的底层通信


image.png

相关文章

  • 3.Dubbo服务调用过程

    dubbo 请求调用过程分析http://blog.csdn.net/paul_wei2008/article/d...

  • Java进阶-Dubbo-进阶

    一、服务调用过程 1.1 服务调用方式   Dubbo 服务调用过程:   Dubbo 支持同步和异步两种调用方式...

  • 服务调用过程

    目的 生成类代理,调用本地/远程方法 方式 基于Spring FactoryBean,通过ReferenceBea...

  • RPC

    RPC调用过程 由于各服务部署在不同机器,服务间的调用免不了网络通信过程,服务消费方每调用一个服务都要写一坨网络通...

  • Dubbo篇

    RPC原理和调用过程 1)客户端 RpcClinet 发现服务2)调用者 Caller 调用服务 RemoteAP...

  • LinkedHashMap 不能强转为自定义的对象的解决方案

    问题描述 Java 微服务项目开发过程中,使用 feign 进行服务调用,A服务调用B服务,A服务接收到数据进行处...

  • dubbo源码分析-服务调用

    dubbo服务调用,就是服务消费者发起调用服务提供者接口的过程。是对前面服务导出,服务引用,服务集群、路由和负载均...

  • 手撸一个RPC框架

    如何调用他人的远程服务? 由于各服务部署在不同机器,服务间的调用免不了网络通信过程,服务消费方每调用一个服务都要写...

  • Dubbo

    Dubbo(服务治理框架) RPC 各服务都要实现rpc协议,才能实现服务间的调用 rpc:远程过程调用协议,是一...

  • RPC原理

    服务调用 由于各服务部署在不同机器,服务间的调用免不了网络通信过程,服务消费方每调用一个服务都要写一坨网络通信相关...

网友评论

    本文标题:3.Dubbo服务调用过程

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