iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >java开发分布式服务框架Dubbo暴露服务的示例分析
  • 953
分享到

java开发分布式服务框架Dubbo暴露服务的示例分析

2023-06-25 15:06:44 953人浏览 独家记忆
摘要

小编给大家分享一下java开发分布式服务框架dubbo暴露服务的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Dubbo服务暴露机制前言在进行服务暴露机制的分析之前,必须谈谈什么是URL,在Dubbo服务暴露过程中

小编给大家分享一下java开发分布式服务框架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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

从上述源码中可以看到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()

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

本地暴露

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

为什么要封装成invoker呢?

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

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

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

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

java开发分布式服务框架Dubbo暴露服务的示例分析

远程暴露

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

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

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

然后进入 doLocalExport 方法内部

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

java开发分布式服务框架Dubbo暴露服务的示例分析

需要创建server

java开发分布式服务框架Dubbo暴露服务的示例分析

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

至此服务暴露流程结束。

java开发分布式服务框架Dubbo暴露服务的示例分析

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

java开发分布式服务框架Dubbo暴露服务的示例分析

看完了这篇文章,相信你对“java开发分布式服务框架Dubbo暴露服务的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: java开发分布式服务框架Dubbo暴露服务的示例分析

本文链接: https://www.lsjlt.com/news/305664.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java开发分布式服务框架Dubbo暴露服务的示例分析
    小编给大家分享一下java开发分布式服务框架Dubbo暴露服务的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Dubbo服务暴露机制前言在进行服务暴露机制的分析之前,必须谈谈什么是URL,在Dubbo服务暴露过程中...
    99+
    2023-06-25
  • java开发分布式服务框架Dubbo暴露服务过程详解
    目录Dubbo服务暴露机制前言服务暴露流程源码解析本地暴露远程暴露Dubbo服务暴露机制 前言 在进行服务暴露机制的分析之前,必须谈谈什么是URL,在Dubbo服务暴露过程中URL是...
    99+
    2024-04-02
  • java开发分布式服务框架Dubbo原理机制的示例分析
    这篇文章给大家分享的是有关java开发分布式服务框架Dubbo原理机制的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言在介绍Dubbo之前先了解一下基本概念:Dubbo是一个RPC框架,RPC,即Re...
    99+
    2023-06-25
  • java开发分布式服务框架Dubbo调用过程
    目录大致流程调用请求的具体信息协议Dubbo协议序列化器调用流程图调用流程源码分析——客户端模板方法模式路由和负载均衡调用的三种方式调用流程源码分析——服务端总结大致流程 客户端根据...
    99+
    2024-04-02
  • Java分布式服务框架Dubbo介绍
    目录1、什么是Dubbo?2、Dubbo核心组件是?3、Dubbo的工作原理是?4、介绍一下Dubbo框架分层?5、Dubbo支持哪些协议?1.dubbo默认协议:2.rmi协议:3...
    99+
    2024-04-02
  • java开发分布式服务框架Dubbo服务引用过程详解
    目录大致流程服务引用策略服务引用的三种方式服务引入流程解析总结大致流程 Provider将服务暴露出来并且注册到注册中心,而Consumer通过注册中心获取Provider的信息,之...
    99+
    2024-04-02
  • java开发分布式服务框架Dubbo原理机制详解
    目录前言Dubbo框架有以下部件ConsumerProviderRegistryMonitorContainer架构高可用性框架设计服务暴露过程服务消费过程前言 在介绍Dubbo之前...
    99+
    2024-04-02
  • 分布式服务Dubbo+Zookeeper安全认证的示例分析
    这篇文章给大家分享的是有关分布式服务Dubbo+Zookeeper安全认证的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。问题Zookeeper+dubbo,如何设置安全认证?不想让其他服务连接Zooke...
    99+
    2023-05-30
    dubbo zookeeper
  • Java的任务调度框架cron4j 2.2.5发布的示例分析
    Java的任务调度框架cron4j 2.2.5发布的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。cron4j 2.2.5 发布了,主要改进有:Predictor ...
    99+
    2023-06-17
  • CSS框架开发的示例分析
    这期内容当中小编将会给大家带来有关CSS框架开发的示例分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 Philip Walton 在AppFolio担任前端工程师,他...
    99+
    2024-04-02
  • php开发框架的示例分析
    这篇文章给大家分享的是有关php开发框架的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、LaravelLaravel是一款免费并且开源的PHP应用框架,它是为开发基于MVC的WEB应用而设计的,个人觉...
    99+
    2023-06-14
  • Java详细分析LCN框架分布式事务
    目录2PC两阶段提交协议LCNLCN基本实现原理搭建全局协调者使用LCN解决分布式事务问题源码分析2PC两阶段提交协议 分布式事务通常采用2PC协议,全称Two Phase Comm...
    99+
    2024-04-02
  • 分布式微服务云架构实例分析
    今天就跟大家聊聊有关分布式微服务云架构实例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。源码结构JEESZ驱动式项目构建内置高效可靠的代码生成器支持多种数据模型,根据数据库表生成...
    99+
    2023-06-05
  • Java开发人员依赖Spring框架的示例分析
    Java开发人员依赖Spring框架的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Diffblue 与 Vanson Bourn...
    99+
    2024-04-02
  • 支持python分布式计算框架Ray的示例分析
    这篇文章将为大家详细讲解有关支持python分布式计算框架Ray的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、简介Ray为构建分布式应用程序提供了一个简单、通用的API。Ray是一种分布式执...
    99+
    2023-06-20
  • SpringCloud分布式微服务b2b2c电子商务分布式微服务中docker-feign-hystrix的示例分析
    这篇文章主要介绍SpringCloud分布式微服务b2b2c电子商务分布式微服务中docker-feign-hystrix的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、创建模块(microservice...
    99+
    2023-06-05
  • Winform开发框架演化历史的示例分析
    这篇文章主要介绍了Winform开发框架演化历史的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、传统Winform开发框架我这里指的传统Winform开发框架,就...
    99+
    2023-06-17
  • Oracle推出轻量级Java微服务框架Helidon的示例分析
    Oracle推出轻量级Java微服务框架Helidon的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。近日,Oracle 推出 了一个新的开源框架&...
    99+
    2023-06-19
  • web开发之响应式布局的示例分析
    这篇文章将为大家详细讲解有关web开发之响应式布局的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、前言响应式Web设计可以让一个网站同时适配多种设备和多个屏幕...
    99+
    2024-04-02
  • 微信小程序开发框架MINA的示例分析
    这篇文章将为大家详细讲解有关微信小程序开发框架MINA的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。小程序MINA框架,及优点MINA框架:小程序使用的是MIN...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作