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 链嵌入扩展点(如监控、鉴权),实现高可定制化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码的余温

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值