欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

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

时间:2023-07-21

​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 

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

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。