dubbo学习日记(一)-------dubbo引用服务过程

本文详细介绍了Dubbo服务引用的过程,从配置文件解析到ReferenceBean的初始化,再到RegistryProtocol的refer方法调用,涉及服务注册、动态发现机制。在服务注册过程中,消费者向注册中心注册,并订阅服务变更。当服务提供者信息发生变化时,消费者会接收到通知并刷新服务列表。整个过程展示了Dubbo如何通过SPI实现协议扩展,并利用JavassistProxyFactory生成代理类,实现服务调用。
摘要由CSDN通过智能技术生成

首先上dubbo调用服务经典流程图:

dubbo配置基于 Spring 的 Schema 和 XML 扩展机制实现,dubbo的配置文件会通过dubbo自定义的标签解析器去解析。reference标签会解析成对应的ReferenceBean。

 ReferenceBean实现spring 接口InitializingBean的afterPropertiesSet方法,所以bean初始化会执行afterPropertiesSet,dubbo配置init为加载时即刻初始化,就是afterPropertiesSet()--->getObject()---->ReferenceBean的父类ReferenceConfig的init方法,init的方法中主要是做了新旧版本的兼容,消费者全局配置信息的获取,校验配置信息等操作,最后将消费者配置信息封装成map创建代理对象。

 createProxy(Map)根据配置信息中注册中心类型,非本地暴露,非直连,通过注册中心配置拼url,通过refprotocol.refer调用RegistryProtocol的refer方法(这里说一下,RegistryProtocol是Protocol接口的一个实现类,Protocol接口有很多的实现类,dubbo支持多种协议,通过配置动态支持不同协议的实现是基于dubbo的SPI(服务发现),通过适配注解@Adaptive,通过动态代理生成代理类Protocol$Adaptive,通过dubbo全局Url获取配置的对应协议的实现类。)

上面方法栈信息可以看出,生成的代理类,以及调用RegistryProtocol之前经过的两个装饰类(稍后补充解释该两个类的作用)。 

RegistryProtocol的refer方法主要是使用注册中心地址获取注册中心实例,调用doRefer方法

在doRefer里面主要通过RegistryDirectory类完成了消费者向注册中心注册,和订阅服务。 

 通过zookeeper的client可以看到对应服务的节点下面多了consumer文件夹,说明消费者已经注册完毕。

 该接口zookeeper节点下面有四个节点consumer,configurators,routers,providers,随后会同步消费者注册地址订阅该目录下的四个文件的变化,一旦发生更改,删除,增加,就会触发订阅的回调,实现”动态“发现机制。 最后回到RegistryDirectory的notify方法,该方法会将zookeeper变化配置信息,路由信息,服务提供者放到list分别处理,

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值