Dubbo暴露服务过程

Dubbo服务暴露机制

前言

在进行服务暴露机制的分析之前,必须谈谈什么是URL,在Dubbo服务暴露过程中URL是无处不在的,贯穿了整个过程。

一般情况下,URL指的是统一资源定位符,标准格式如下:

protocol://host:port/path?key1=value1&key2=value2

Dubbo就是用这种URL的方式来作为约定的参数类型,服务之间也是用URL来进行交互。

Dubbo用URL作为配置总线,贯穿整个源码体系。

URL的具体参数如下:

  • protocol:dubbo中的各种协议,如:dubbo、http、thrift
  • host/port:主机/端口号
  • path:接口名称
  • parameters:参数键值对

服务暴露流程

大体流程分为三个步骤:

  • 检测配置,有些配置为空值会有默认值自动填充并自动组装为URL
  • 暴露服务,包括暴露到本地和远程的服务
  • 注册为服务到服务注册中心

源码解析

先来到ServiceBean

在这里插入图片描述

可以看到这个类实现了ApplicationListener<ContextRefreshedEvent>,这样就会在Spring IOC容器刷新之后调用onApplicationEvent方法,这个方法中做的就是服务暴露

在这里插入图片描述

if判断条件中,我们可以看到如果配置中没有设置延迟暴露、并且没有暴露过、并且支持暴露的情况下就会执行this.export(),最终会调用父类ServiceConfig中的export方法。

请添加图片描述

上述方法中主要就是进行配置检查,然后进入this.doExport()进行服务暴露,这个方法前面的部分都是一些配置检查,重点放在最后的this.doExportUrls()

请添加图片描述

从上述源码中可以看到Dubbo是支持多注册中心的,并且支持多种协议,一个服务如果有多个协议那么都需要暴露。this.loadRegistries()是根据配置组装成注册中心相关的URL,如下:

registry://127.0.0.1:2181/com.alibaba.dubbo.registry.RegistryService?application=user-service-provider-one&dubbo=2.6.2&pid=29056&registry=zookeeper&timestamp=1632309180780

接下来进入this.doExportUrlsFor1Protocol()

在这里插入图片描述

构建完成之后的URL如下图所示:

请添加图片描述

使用的是dubbo协议,接下来要做的就是根据URL来进行服务暴露

在这里插入图片描述

本地暴露

进入exportLocal()看一下,这个方法做的事就是进行本地暴露,使用的是injvm协议,这个方法中对URL进行修改,将协议改为injvm

在这里插入图片描述

此处的protocol.export()是标注了@Adaptive注解的,设计自适应拓展,调用该方法之后会生成代理类,代理类通过URL中的参数得知所使用的协议,然后通过Dubbo SPI机制实现拓展,选择对应的实现类进行export()方法,此处的方法会选择InjvmProtocol中的export()进行暴露。

在这里插入图片描述

在这里插入图片描述

经过转化后得到的export如下所示:

在这里插入图片描述

如图所示,具体实现类被层层包装。

为什么要封装成invoker呢?

封装成invoker是为了屏蔽调用的细节,统一暴露出一个可执行体,使得调用者调用时变得便捷简易。

为什么要使用本地暴露呢?

因为可能存在本地不同服务之间相互调用的情况,因此本地暴露后,内部可以直接进行调用,而省去了不必要的网络通信。

此处引用一下博主敖丙的文章中的本地暴露流程图

在这里插入图片描述


远程暴露

此时本地暴露已经完成了,现在开始远程暴露。

在这里插入图片描述

流程与本地暴露相似,都需要先封装为invoker然后再进一步生成exporter,以下是registryURL.addParameterAndEncoded()方法将URL进行拼接后的结果:

在这里插入图片描述

可以看到先是走registry协议,然后参数中有一个export=dubbo://,此时会走dubbo协议,所以我们得知SPI会先通过registry协议找到RegistryPotocol然后执行export(),然后再执行DubboPotocol中的export()

现在我们进入RegistryPotocol中的export()方法。

在这里插入图片描述

上述操作主要是讲export转化为exporter,获取注册中心的相关配置,如果需要注册则向注册中心进行注册,并且在ProviderConsumerRegTable中记录服务提供者信息,进入源码中,我们发现实质就是往一个ConcurrentHashMap中塞入invoker,key是服务接口全类名,value是一个set,set中存储包装过的invoker。

在这里插入图片描述

然后进入 doLocalExport 方法内部

在这里插入图片描述

箭头指向的方法最终会调用DubboProtocol中的export()

在这里插入图片描述

在这里插入图片描述

需要创建server

在这里插入图片描述

上述代码中,主要就是根据URL创建出key,然后将key和invoker存入exporterMap中关联起来,如果是初次服务暴露则需要创建监听服务器,默认是NettyServer,并且初始化各种Handler,比如心跳检测,解码等。

至此服务暴露流程结束。

在这里插入图片描述

此处引用博主敖丙的文章中的本地暴露流程图

在这里插入图片描述

以上。

整理不易,如果对你有帮助留个三连吧!

如果不足或错误欢迎评论指正。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Dubbo 是一种分布式服务框架,它支持高性能的远程服务调用和服务治理。下面是 Dubbo 服务暴露过程: 1. 配置服务接口:首先,你需要定义一个服务接口,它描述了你希望暴露服务的方法和参数。 2. 实现服务接口:然后,你需要编写一个类来实现这个服务接口,提供具体的业务逻辑实现。 3. 配置服务实现:在 Dubbo 的配置文件中,你需要配置服务的实现类,指定要暴露的接口和端口等信息。 4. 启动 Dubbo 服务:在应用启动时,Dubbo 框架会根据配置文件初始化相关的组件,并启动服务提供者。 5. 注册服务Dubbo 服务提供者会将自己的地址、接口和方法等信息注册到注册中心,以便消费者能够发现和调用该服务。 6. 监听请求:一旦 Dubbo 服务提供者启动成功并注册到注册中心,它就会开始监听来自消费者的远程调用请求。 7. 处理请求:当有消费者发起远程调用请求时,Dubbo 服务提供者会根据请求的接口和方法等信息,找到对应的实现类并执行相应的业务逻辑。 8. 返回结果:Dubbo 服务提供者执行完业务逻辑后,会将结果返回给消费者,完成一次远程调用。 总结来说,Dubbo 服务暴露过程包括定义服务接口、实现服务接口、配置服务实现、启动 Dubbo 服务、注册服务、监听请求、处理请求和返回结果等步骤。通过这些步骤,Dubbo 实现了远程服务的调用和治理。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

又蠢又笨的懒羊羊程序猿

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

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

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

打赏作者

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

抵扣说明:

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

余额充值