`
ncs123
  • 浏览: 103356 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Dubbo之RpcContext详解

阅读更多
一、RpcContext简介
    RpcContext 是一个 ThreadLocal 的临时状态记录器,当接收到 RPC 请求,或发起 RPC 请求时,RpcContext 的状态都会变化。
    比如:A调B,B再调C,则B机器上,在B调C之前,RpcContext记录的是A调B的信息,在B调C之后,RpcContext记录的是B调C的信息。

二、RpcContext的使用
    消费端
// 远程调用之前,通过attachment传KV给提供方
RpcContext.getContext().setAttachment("userKey", "userValue");
// 远程调用
xxxService.xxx();
// 本端是否为消费端,这里会返回true
boolean isConsumerSide = RpcContext.getContext().isConsumerSide();
// 获取最后一次调用的提供方IP地址
String serverIP = RpcContext.getContext().getRemoteHost();
// 获取当前服务配置信息,所有配置信息都将转换为URL的参数
String application = RpcContext.getContext().getUrl().getParameter("application");
// 注意:每发起RPC调用,上下文状态会变化
yyyService.yyy();
// 此时 RpcContext 的状态已变化 
RpcContext.getContext();  


    服务端
public class XxxServiceImpl implements XxxService {

    public void xxx() {
        // 通过RpcContext获取用户传参,这里会返回userValue
        String value = RpcContext.getContext().getAttachment("userKey");
        // 本端是否为提供端,这里会返回true
        boolean isProviderSide = RpcContext.getContext().isProviderSide();
        // 获取调用方IP地址
        String clientIP = RpcContext.getContext().getRemoteHost();
        // 获取当前服务配置信息,所有配置信息都将转换为URL的参数
        String application = RpcContext.getContext().getUrl().getParameter("application");
        // 注意:每发起RPC调用,上下文状态会变化
        yyyService.yyy();
        // 此时本端变成消费端,这里会返回false
        boolean isProviderSide = RpcContext.getContext().isProviderSide();
    } 
}


三、RpcContext原理
    消费端在执行Rpc调用之前,经过Filter处理, 会将信息写入RpcContext.见ConsumerContextFilter:


    服务端在执行调用之前,也会经过Filter处理,将信息写入RpcContext. 见ContextFilter


四、Dubbo异步调用
//配置方式
<dubbo:reference id="demoServicemy2" interface="com.test.dubboser.ServiceDemo2">
      <dubbo:method name="getPerson" async="true"  />
</dubbo:reference>

//编程方式
Future<T> future = RpcContext.getContext().asyncCall(new Callable<T>(){...});

//访问服务之后获取异步调用的结果,通过Future.
Future<T> future = RpcContext.getContext().getFuture();
T t = future.get();

五、Dubbo异步调用源码解析
    同步调用:ResponseFuture.get()同步等待返回结果并实时返回。
    异步调用:ResponseFuture放入RpcContext,实时返回一个空的RpcResult实例,后序通过RpcContext.getContext().getFuture() .get()获取返回值。

    详情见DubboInvoker


六、Dubbo异步调用的坑
    异步调用依赖传递性
   
  • 问题表现:如果consumer-A异步调用provider-B,而provider-B本身又调用了provider-C。当provider-B调用provider-C时,会变成异步。
  • 问题原因:是否异步调用取决于RpcContext中async的值,其次才是服务本身的配置。当A调用B时,会把async=true传给B的RpcContext;B调用C时,虽然服务本身async=false,但RpcContext中async=true,自然也就成了异步调用。


    异步回调返回null
   
  • 问题表现:consumer-A调用provider-B,而provider-B本身又调用了provider-C。consumer-A调用provider-B返回null。
  • 问题原因:异步调用直接返回空的RpcResult实例,需要后序通过RpcContext.getContext().getFuture() .get()获取返回值。async透传到provider-B端之后,也是异步调用provider-C,但是直接返回空的RpcResult实例给consumer-A。

    解决方案:别让async参数应用到provider端。
    修改ContextFilter源码,重写RpcContext时删除async参数



   
  • 大小: 72.9 KB
  • 大小: 96.8 KB
  • 大小: 169.5 KB
  • 大小: 131.2 KB
分享到:
评论

相关推荐

    dubbo+zookeeper案例,dubbo和Zookeeper详解,Java

    《Dubbo与Zookeeper在分布式环境中的应用解析》 Dubbo和Zookeeper是两个在分布式系统中广泛应用的技术,它们在构建高效、可扩展的服务架构中起着关键作用。本篇文章将深入探讨这两个技术以及如何结合使用,以实现一...

    第四课:Dubbo调用模块详解 (2)1

    《Dubbo调用模块详解:深入理解异步调用与容错策略》 在分布式服务框架Dubbo中,调用模块扮演着至关重要的角色,它负责实现远程方法调用并确保返回结果的顺利获取。本篇文章将深入探讨Dubbo调用模块的基本组成,...

    第四课:Dubbo调用模块详解1

    【Dubbo调用模块详解1】 Dubbo作为一款高性能的Java RPC框架,其调用模块是其核心组件之一,负责发起远程方法调用并获取返回结果。本篇将详细解析Dubbo调用模块的基本组成、非典型使用场景以及内部实现源码分析。 ...

    dubbo+zookeeper案例,dubbo和Zookeeper详解,Java源码.zip

    《Dubbo与Zookeeper深度解析:Java源码实践》 在现代分布式系统中,服务治理是不可或缺的一部分。Dubbo和Zookeeper作为两个重要的组件,分别承担了服务治理和注册中心的角色,它们共同构建了高效、稳定的微服务体系...

    Dubbo分布式框架详解.rar

    1. **安装Zookeeper**:首先需要在服务器上安装并启动Zookeeper,确保服务提供者和消费者能与之通信。 2. **集成Dubbo**:在你的项目中引入Dubbo的依赖,根据官方文档配置相关的XML或Java配置,包括服务接口、实现...

    Apache Dubbo:Dubbo配置与参数详解

    ### Apache Dubbo:Dubbo配置与参数详解 #### 一、Dubbo概述 Apache Dubbo是一款高性能、轻量级的微服务框架,主要用于构建服务化的应用程序和服务治理平台。它提供了全面的服务治理解决方案,包括服务发布、发现...

    Dubbo与Zookeeper详细例子

    【标题】: "Dubbo与Zookeeper详细例子" 涉及的核心技术是分布式服务框架Dubbo和分布式协调服务Zookeeper。这两个组件在现代大型分布式系统中起着至关重要的作用。 【Dubbo】:Dubbo是由阿里巴巴开源的一款高性能、...

    阿里分布式开源框架dubbo视频详解+zookeepter+mycat

    包含阿里分布式开源框架dubbo视频详解,dubbo工具包,源码分析,zookeepr视频,mycat介绍

    dubbo的原理简要概述以及zookeeper的使用

    dubbo概述,简要描述了一下dubbo以及zookeeper的使用和原理

    dubbo示例代码dubbo-sample

    【Dubbo 示例代码详解】 Dubbo 是阿里巴巴开源的一款高性能、轻量级的Java服务治理框架,它主要提供了RPC(远程过程调用)服务,并且包含了服务注册与发现、负载均衡、容错处理、监控等全面的服务治理功能。本示例...

    dubbo详解part1

    dubbo详解part1

    dubbo详解part2

    dubbo详解part2

    dubbo详解part3

    dubbo详解part3

    dubbo详解part4

    dubbo详解part4

    dubbo+zookpeer+srpingmvc

    在IT行业中,构建高效、可扩展的企业级应用是至关重要的,而"Dubbo + ZooKeeper + SpringMVC"的组合正是为了实现这一目标的一种常见架构模式。这个资源集合提供了所有必要的组件,包括jar包和开发环境,帮助开发者...

    Dubbo之《尚硅谷》学习笔记.md

    Dubbo之《尚硅谷》学习笔记

    dubbo的配置文件详解(推荐)

    Dubbo是一款高性能、轻量级的Java RPC框架,它提供了从服务注册与发现、服务调用、负载均衡、容错机制到服务治理等一系列完整的解决方案。在使用Dubbo时,配置文件起着至关重要的作用,它们定义了服务的元信息、协议...

Global site tag (gtag.js) - Google Analytics