当前位置: 首页>后端>正文

Dubbo 书 dubbo书籍 对比




Dubbo 书 dubbo书籍 对比,Dubbo 书 dubbo书籍 对比_springcloud架构特点,第1张


微服务架构是互联网很热门的话题,是互联网技术发展的必然结果。它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。虽然微服务架构没有公认的技术标准和规范或者草案,但业界已经有一些很有影响力的开源微服务架构框架提供了微服务的关键思路,例如Dubbo和Spring Cloud。各大互联网公司也有自研的微服务框架,但其模式都于这二者相差不大。

《Dubbo和springcloud微服务架构到底孰优孰劣》这本书就是对Dubbo和springcloud做了对比。本文主要围绕微服务的技术选型、通讯协议、服务依赖模式、开始模式、运行模式等几方面来综合比较Dubbo和Spring Cloud 这2种开发框架。架构师可以根据公司的技术实力并结合项目的特点来选择某个合适的微服务架构平台,以此稳妥地实施项目的微服务化改造或开发进程。

一、核心部件

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

1、总体架构

(1)Dubbo 核心部件(如下图):

Provider: 暴露服务的提供方,可以通过jar或者容器的方式启动服务

Consumer:调用远程服务的服务消费方。

Registry: 服务注册中心和发现中心。

Monitor: 统计服务和调用次数,调用时间监控中心。(dubbo的控制台页面中可以显示,目前只有一个简单版本)

Container:服务运行的容器。


Dubbo 书 dubbo书籍 对比,Dubbo 书 dubbo书籍 对比_Cloud_02,第2张


(2)Spring Cloud总体架构如下图

Service Provider: 暴露服务的提供方。

Service Consumer:调用远程服务的服务消费方。

EureKa Server: 服务注册中心和服务发现中心。


Dubbo 书 dubbo书籍 对比,Dubbo 书 dubbo书籍 对比_Dubbo 书_03,第3张


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

2、微服务架构核心要素


Dubbo 书 dubbo书籍 对比,Dubbo 书 dubbo书籍 对比_springcloud架构特点_04,第4张


Dubbo只是实现了服务治理,而Spring Cloud子项目分别覆盖了微服务架构下的众多部件而服务治理只是其中的一个方面。Dubbo提供了各种Filter,对于上述中“无”的要素,可以通过扩展Filter来完善。

二、通讯协议

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

(一)、支持协议

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

dubbo:Dubbo缺省协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况

2、Spring Cloud:Spring Cloud 使用HTTP协议的REST API

(二)、性能比较

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


Dubbo 书 dubbo书籍 对比,Dubbo 书 dubbo书籍 对比_springcloud的简单使用_05,第5张


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

三、服务依赖方式

Dubbo服务依赖略重,需要有完善的版本管理机制,但是程序入侵少。而Spring Cloud通过Json交互,省略了版本管理的问题,但是具体字段含义需要统一管理,自身Rest API方式交互,为跨平台调用奠定了基础。

四、组件运行流程

业务部署方式相同,都需要前置一个网关来隔绝外部直接调用原子服务的风险。Dubbo需要自己开发一套API 网关,而Spring Cloud则可以通过Zuul配置即可完成网关定制。使用方式上SpringCloud略胜一筹。


https://www.xamrdz.com/backend/3r31938736.html

相关文章: