Dubbo服务引用原理

服务引用细节

在整体上看,Dubbo框架做服务消费也分为两大部分,第一步通过持有远程服务实例生成Invoker,这个Invoker在客户端是核心的远程代理对象。第二步会把Invoker通过动态代理转换成实现用户接口的动态代理引用。这里的Invoker承载了网络连接、服务调用和重试等功能,在客户端,它可能是一个远程的实现,也可能是一个集群实现。

img

这个图实际上说的并不好,实际上我们是在RegistryProtocol(注册中心)refer到了RegistryDirectory(服务提供者的动态刷新类)然后被我们封装成了一个聚合的clusterinvoker,屏蔽了底层复杂的处理细节。然后通过代理再将invoker封装成我们具体的接口实现类。这样我们看似拿到了接口,实际调用的时候,会传入参数,匹配上方法名,进入invoker的复杂逻辑处理。具体的细节,在服务调用的流程中也可以看见。

具体调用时候用什么样的协议调用,取决于服务暴露的时候是暴露出什么协议的服务,大部分是DubboProtocol。

img

提前给大家看一张dubbo服务调用的过程图,可能会对服务引用的逻辑梳理更有帮助。

img

阅读源码

对服务引用有了个大致的认识后,可以根据资料,阅读源码,去深入了解这些经常被提起的模块。

官网服务引用源码

深度解析dubbo服务本地引用(injvm)

深度解析dubbo服务远程引用(创建Proxy流程)

深度解析dubbo服务远程引用(initClient)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值