Dubbo与Spring Cloud优缺点分析(文档学习个人理解)
创始人
2024-05-26 00:54:37
0

文章目录

  • 核心部件
  • 1、总体框架
    • 1.1 Dubbo 核心部件如下
    • 1.2 Spring Cloud 总体架构
  • 2、微服务架构核心要素
  • 3、通讯协议
    • 3.1 Dubbo
    • 3.2 Spring Cloud
    • 3.3 性能比较
  • 4、服务依赖方式
    • 4.1 Dubbo
    • 4.2 Spring Cloud
  • 5、组件运行流程
    • 5.1 Dubbo
    • 5.2 Dubbo 运行组件
    • 5.3 Spring Cloud
    • 5.4 Spring Cloud 运行组件
  • 6、微服务架构组成以及注意事项
    • 6.1 架构分解
    • 6.2 注意事项
  • 7、总结

核心部件

微服务的核心要素在于服务的服务的发现、注册、路由、熔断、降级、分布式配置,基于上诉几种必要条件对 Dubbo 和Spring Cloud 做出对比

1、总体框架

1.1 Dubbo 核心部件如下

  • Provider:暴露服务的提供方,可以通过jar或者容器的方式启动服务。
  • Consumer:调用远程服务的服务消费方
  • Registry:服务注册中和发现中心
  • Monitor:统计服务和调用次数,调用时间监控中心。(Dubbo 的控制台页面中可以显示,目前只有一个简单版本)
  • Container:服务运行的容器
    在这里插入图片描述

1.2 Spring Cloud 总体架构

  • Service Provider:暴露服务的提供方
  • Service Consumer:调用远程服务的服务消费方
  • Eureka Server:服务注册中心和服务发现中心
    在这里插入图片描述

总结:从整体架构上来看,二者模式接近,都需要服务提供方,注册中心,服务消费方

2、微服务架构核心要素

核心要素DubboSpring Cloud
服务注册中心Zookeeper、RedisSpring Cloud Netflix Eureka
服务调用方式RPCREST API
服务网关Spring Cloud Netflix Zuul
断路器不完善Spring Cloud Netflix Hystrix
分布式配置Spring Cloud Config
分布式追踪Spring Cloud Sleuth
消息总线Spring Cloud Bus
数据流Spring Cloud Stream 基于Redis,Rabbit,Kafka 实现的消息微服务
批量任务Spring Cloud Task

Dubbo 只是实现了服务治理,而 Spring Cloud 子项目分别覆盖了微服务架构下的众多部件,服务治理只是其中的一个方面。

Dubbo 提供了各种 Filter,对于上述中“无”的要素,可以通过扩展 Filter 来完善。例如:

  • 分布式配置:可以使用淘宝的 diamond、百度的 disconf 来实现分布式配置管理。
  • 服务跟踪:可以使用京东开源的 Hydra,或者扩展 Filter 用 Zippin 来做服务跟踪。
  • 批量任务:可以使用当当开源的 Elastic-Job、tbschedule。

总结 : 从核心要素来看,Spring Cloud 更胜一筹,在开发过程中只要整合 Spring Cloud 的子项目就可以顺利的完成各种组件的融合,而 Dubbo 却需要通过实现各种 Filter 来做定制,开发成本以及技术难度略高。

3、通讯协议

基于通讯协议层面对2种框架支持的协议类型以及运行效率方面进行比较

3.1 Dubbo

Dubbo 使用RPC通讯协议,提供序列化方式如下:

  • Dubbo:Dubbo 缺省协议采用单一长连接和 NIO 异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况。
  • RMI:RMI 协议采用 JDK 标准的 java.rmi.* 实现,采用阻塞式短连接和 JDK 标准序列化方式。
  • Hessian:Hessian 协议用于集成 Hessian 的服务,Hessian 底层采用 HTTP 通讯,采用 - Servlet 暴露服务,Dubbo 缺省内嵌 Jetty 作为服务器实现。
  • HTTP:采用 Spring 的 Http Invoker 实现。
  • Webservice:基于 CXF 的 frontend-simple 和 transports-http 实现。

3.2 Spring Cloud

  • Spring Cloud 使用HTTP协议的REST API

3.3 性能比较

使用一个 Pojo 对象包含 10 个属性,请求 10 万次,Dubbo 和 Spring Cloud 在不同的线程数量下,每次请求耗时(ms)如下:

线程数DubboSpring Cloud
10线程2.756.52
20线程4.1810.03
50线程10.328.14
100线程20.1355.23
200线程42110.21

说明:客户端和服务端配置均采用阿里云的 ECS 服务器,4 核 8G 配置,Dubbo 采用默认的 Dubbo 协议。

总结 : Dubbo 支持各种通信协议,而且消费方和服务方使用长链接方式交互,通信速度上略胜 Spring Cloud,如果对于系统的响应时间有严格要求,长链接更合适。

4、服务依赖方式

4.1 Dubbo

服务提供方与消费方通过接口的方式依赖,服务调用设计如下:

  • Interface 层:服务接口层,定义了服务对外提供的所有接口。
  • Molel 层:服务的 DTO 对象层。
  • Business层:业务实现层,实现 Interface 接口并且和 DB 交互。

因此需要为每个微服务定义各自的 Interface 接口,并通过持续集成发布到私有仓库中。调用方应用对微服务提供的抽象接口存在强依赖关系,开发、测试、集成环境都需要严格的管理版本依赖。

通过 maven 的 install & deploy 命令把 Interface 和 Model 层发布到仓库中,服务调用方只需要依赖 Interface 和 Model 层即可。

在开发调试阶段只发布 Snapshot 版本,等到服务调试完成再发布 Release 版本,通过版本号来区分每次迭代的版本。通过 xml 配置方式即可接入 Dubbo,对程序无入侵。

在这里插入图片描述

4.2 Spring Cloud

服务提供方和服务消费方通过 Json 方式交互,因此只需要定义好相关 Json 字段即可,消费方和提供方无接口依赖。通过注解方式来实现服务配置,对于程序有一定入侵。
在这里插入图片描述

总结 : Dubbo 服务依赖略重,需要有完善的版本管理机制,但是程序入侵少。

而 Spring Cloud 通过 Json 交互,省略了版本管理的问题,但是具体字段含义需要统一管理,自身 Rest API 方式交互,为跨平台调用奠定了基础。

5、组件运行流程

5.1 Dubbo

下图中的每个组件都是需要部署在单独的服务器上,Gateway 用来接受前端请求、聚合服务,并批量调用后台原子服务。每个 Service 层和单独的 DB 交互。
在这里插入图片描述

5.2 Dubbo 运行组件

  • Gateway:前置网关,具体业务操作,Gateway 通过 Dubbo 提供的负载均衡机制自动完成。
  • Service:原子服务,只提供该业务相关的原子服务。
  • Zookeeper:原子服务注册到 ZK 上。

5.3 Spring Cloud

在这里插入图片描述

5.4 Spring Cloud 运行组件

  • 所有请求都统一通过 API 网关(Zuul)来访问内部服务。
  • 网关接收到请求后,从注册中心(Eureka)获取可用服务。
  • 由 Ribbon 进行均衡负载后,分发到后端的具体实例。
  • 微服务之间通过 Feign 进行通信处理业务。

总结 : 业务部署方式相同,都需要前置一个网关来隔绝外部直接调用原子服务的风险。

Dubbo 需要自己开发一套 API 网关,而 Spring Cloud 则可以通过 Zuul 配置即可完成网关定制。使用方式上 Spring Cloud 略胜一筹。

6、微服务架构组成以及注意事项

到底使用是 Dubbo 还是 Spring Cloud 并不重要,重点在于如何合理的利用微服务。

下面是一张互联网通用的架构图,其中每个环节都是微服务的核心部分。
在这里插入图片描述

6.1 架构分解

  • 网关集群:数据的聚合、实现对接入客户端的身份认证、防报文重放与防数据篡改、功能调用的业务鉴权、响应数据的脱敏、流量与并发控制等。
  • 业务集群:一般情况下移动端访问和浏览器访问的网关需要隔离,防止业务耦合。
  • Local
    Cache:由于客户端访问业务可能需要调用多个服务聚合,所以本地缓存有效的降低了服务调用的频次,同时也提示了访问速度。本地缓存一般使用自动过期方式,业务场景中允许有一定的数据延时。
  • 服务层:原子服务层,实现基础的增删改查功能,如果需要依赖其他服务需要在 Service 层主动调用。
  • Remote Cache:访问 DB 前置一层分布式缓存,减少 DB 交互次数,提升系统的TPS。
  • DAL:数据访问层,如果单表数据量过大则需要通过 DAL 层做数据的分库分表处理。
  • MQ:消息队列用来解耦服务之间的依赖,异步调用可以通过 MQ 的方式来执行。
  • 数据库主从:服务化过程中必经的阶段,用来提升系统的 TPS。

6.2 注意事项

  • 服务启动方式建议使用jar方式启动,启动速度快,更容易监控。
  • 缓存、缓存、缓存,系统中能使用缓存的地方尽量使用缓存,通过合理的使用缓存可以有效的提高系统的TPS。
  • 服务拆分要合理,尽量避免因服务拆分而导致的服务循环依赖。
  • 合理的设置线程池,避免设置过大或者过小导致系统异常。

7、总结

Dubbo 出生于阿里系,是阿里巴巴服务化治理的核心框架,并被广泛应用于中国各互联网公司;只需要通过 Spring 配置的方式即可完成服务化,对于应用无入侵,设计的目的还是服务于自身的业务为主。

虽然阿里内部原因 Dubbo 曾经一度暂停维护版本,但是框架本身的成熟度以及文档的完善程度,完全能满足各大互联网公司的业务需求。

如果我们使用配置中心、分布式跟踪这些内容都需要自己去集成,这样无形中增加了使用 Dubbo 的难度。

Spring Cloud 是大名鼎鼎的 Spring 家族的产品, 专注于企业级开源框架的研发。

Spring Cloud 自从发布到现在,仍然在不断的高速发展,几乎考虑了服务治理的方方面面,开发起来非常的便利和简单。

Dubbo 于 2017 年开始又重启维护,发布了更新后的 2.5.7 版本,而 Spring Cloud 更新的非常快。

因此,企业需要根据自身的研发水平和所处阶段选择合适的架构来解决业务问题,不管是 Dubbo 还是 Spring Cloud 都是实现微服务有效的工具。

微服务架构是互联网很热门的话题,是互联网技术发展的必然结果。它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。

相关内容

热门资讯

为什么有些玩家在第五人格中无法... 为什么有些玩家在第五人格中无法打开心灵归宿心灵归宿已经上线,并且已经过了十天了,我却还是无法打开,求...
全国政协十四届三次会议举行第二... 转自:千龙网3月7日,全国政协十四届三次会议在北京人民大会堂举行第二次全体会议。这是全国政协委员走向...
父母爱情中的小演员 父母爱情中的小演员曾经也有一个笑容出现在我的生命里,可是最后还是如雾般消散,而那个笑容,就成为我心中...
报告:职场女性平均月薪8978... 转自:河南商报中新经纬3月6日电 6日,智联招聘发布《2025中国女性职场现状调查报告》。报告称,据...
主管如何做好教练,带好团队 主管如何做好教练,带好团队想要做好教练,带好团队,作为主管来讲,首先要学会管理。如果作为教练来讲,自...
直播电商乱象丛生,市监总局:压... 在当今数字化时代,直播行业蓬勃发展,直播带货已成为一种重要的营销方式。然而,在这看似繁华的背后,却隐...
大学里谈恋爱。 大学里谈恋爱。在大学里一直没遇到自己喜欢的,合适的,有感觉的,想谈场恋爱,没有喜欢的人。常说大学里不...
欧元区面临低增长压力 欧央行降... 转自:新华财经新华财经北京3月7日电 (王晓伟)欧洲央行6日决定将三大关键利率下调25个基点。从20...
荣晟环保跌2.06%,成交额6... 3月7日,荣晟环保盘中下跌2.06%,截至10:57,报13.79元/股,成交6487.89万元,换...
外交主题记者会丨王毅:中方愿同... 来源:央视新闻客户端 今天(3月7日)上午,十四届全国人大三次会议举行记者会,中共中央政治局委员、外...
“日抛”龙凤镯,缓解了年轻人的... 踏入双春闰月婚庆旺年,婚庆金饰备受关注。但金价的持续走高,让备婚年轻人感到焦虑。“金价那么高,结婚有...
神犬小七 电视剧 小七是什么狗 神犬小七 电视剧 小七是什么狗是一种导盲犬 名叫拉布拉多犬小七是拉布拉多犬舍
欧洲央行再次降息 三大关键利率... 中新社北京3月7日电 综合消息:欧洲中央银行6日宣布,将欧元区三大关键利率分别下调25个基点,以应对...
求一本主角穿越到英雄联盟里的小... 求一本主角穿越到英雄联盟里的小说,内容是:主角穿越和娑娜成为兄妹求一本主角穿越到英雄联盟里的小说,内...
破天一剑sf里的支天夜叉 八戒... 破天一剑sf里的支天夜叉 八戒 鬼武 在 哪打?支天夜叉是在50大战 八戒 鬼武 是在冰星里刷
大行评级|摩根大通:对中国收费... 摩根大通发表研报指,对中国收费公路股持乐观看法,认为该板块将迎来估值倍数的重估,因为投资论点从稳定及...
汤唯获亚洲电影大奖卓越亚洲电影... 在亚洲电影的广阔星空中,总有一些闪耀的明星,以其卓越的演技和独特的魅力,照亮了整个影坛。近日,来自 ...
中兴通讯2024年业绩出炉,净... 据中兴通讯(00763.HK, 000063.SZ)所发布公告,其 2024 年度报告展示了公司在复...
西域旅游涨2.11%,成交额9... 3月7日,西域旅游盘中上涨2.11%,截至10:59,报36.83元/股,成交9649.61万元,换...
娱乐00后男人气榜怎么投票? 娱乐00后男人气榜怎么投票?你输入这个 娱乐男明星人气排行榜投票 然后点击第二项 进去之后选择你喜欢...