当前位置: 首页 > news >正文

Dubbo服务调用全流程解析

Dubbo 服务调用过程详解

Dubbo 的调用过程分为服务注册与发现远程调用执行两大阶段,具体流程如下:


一、服务注册与发现
  1. 服务提供者注册

    • 服务提供者(Provider)启动时,将服务接口、实现类、IP 端口等信息注册到注册中心(如 Zookeeper)。
    • 注册中心存储服务元数据,并通知已订阅的消费者更新服务列表。
  2. 服务消费者订阅

    • 消费者(Consumer)启动时,向注册中心订阅所需服务,获取提供者地址列表并缓存在本地。
    • 注册中心通过长连接推送服务变更(如新增/下线提供者)。

二、远程调用执行
  1. 代理层拦截

    • 消费者通过动态代理(JDK 或 Javassist)生成服务接口的代理对象,调用时转为远程 RPC 请求。
  2. 集群容错与负载均衡

    • Directory:从本地缓存获取所有可用的服务提供者(Invoker 列表)。
    • Router:根据路由规则(如标签路由)过滤 Invoker。
    • LoadBalance:按策略(随机、轮询等)选择目标 Invoker。
  3. 网络通信与编码

    • 将方法名、参数类型、参数值等序列化为二进制数据(默认使用 Hessian2)。
    • 通过 Netty 发送 Dubbo 协议数据包(Header + Body 结构,Header 含序列化类型、请求 ID 等)。
  4. 服务端处理

    • 提供者的 NettyServer 接收请求,解码后派发到业务线程池。
    • 通过反射调用真实服务实现,结果序列化后返回。
  5. 结果返回与解码

    • 消费者接收响应数据,解码后唤醒阻塞的调用线程,返回结果。

三、关键设计
  • 协议设计:Dubbo 协议采用 0xdabb 魔数标识,解决 TCP 粘包问题。
  • 异步调用:支持 Future 和回调机制,避免线程阻塞。
  • 容错机制:失败自动重试(默认 2 次)、快速失败等策略。

整个过程通过 Filter 链嵌入扩展点(如监控、鉴权),实现高可定制化。

相关文章:

  • matlab实现轮轨接触几何计算
  • 前置机、跳板机、堡垒机详细介绍及对比
  • 数字孪生技术为UI前端注入新活力:实现智能化交互新体验
  • vue将页面导出pdf,vue导出pdf ,使用html2canvas和jspdf组件
  • OpenCV CUDA模块设备层-----双曲正弦函数sinh()
  • 【linux】程序地址空间
  • AI聊天多分支对话的纯前端实现
  • 19、RocketMQ核⼼编程模型
  • Nestjs框架: nestjs-schedule模块中的三类定时任务
  • 同样是synthesis(综合) HLS和Vivado里面是有什么区别
  • 商品中心—15.库存分桶扣减的技术文档
  • Hyperledger Fabric 入门笔记(二十)Fabric V2.5 测试网络进阶之Tape性能测试
  • 3.Stable Diffusion WebUI本地部署和实践
  • 论分布式设计
  • 基于Redis分布式的限流
  • springboot整合微信App支付以及支付宝App支付
  • opensuse安装rabbitmq
  • 使用 Azure 创建虚拟机所涉及的各项资源和设置
  • 探秘 VR 逃生救援技术的奇妙世界​
  • 鸿蒙HarmonyOS 5小游戏实践:记忆翻牌(附:源代码)