Dubbo服务消费者启动与订阅原理

​Dubbo服务消费方主要是作为客户端向服务提供方发起请求并接受响应的。

它有两个核心能力:

1、订阅和感知最新提供者信息

2、向服务提供者发起rpc请求调用

本文将分析服务消费方的启动和订阅原理。

总共有两种机制时机来引用服务,第1是俄汉式(默认),afterPropertiesSet方法中,第2种是是在 ReferenceBean 对应的服务被注入到其他类中时引用(dubbo:Reference标签中init属性配置成true时候) 

1、ReferenceBean由于实现了FactoryBean,自定义Bean实例化服务Bean过程。spring注册该服务对象到其他bean中的时候,调用com.alibaba.dubbo.config.spring.ReferenceBean#getObject,执行服务应用过程。 

2、前置条件判断,是否已经初始化,配置是否合格,com.alibaba.dubbo.config.ReferenceConfig#init 

3、com.alibaba.dubbo.config.ReferenceConfig#createProxy 创建消费方代理对象

这里要分几种情况:

如果是jvm内调用,生成injvm url

如果是直联方式调用,配置了url的情况,

如果是注册中心方式先创建通信客户端,再创建invoker。 

com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol#initClient 

通过源码可知,在消费者启动过程中,会向注册中心订阅服务提供者信息,并且创建具备通信能力的代理对象,发起远程调用时候直接使用创建好的客户端发起​通信请求。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

服务端技术栈

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

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

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

打赏作者

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

抵扣说明:

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

余额充值