SpringCloud - SpringCloud Netflix v.s Dubbo v.s SpringCloud Alibaba

一、SpringCloud Netflix v.s Dubbo

1.1 微服务核心架构要素PK

结论:Spring Cloud Netflix更胜一筹,在开发过程中只要整合Spring Cloud的子项目就可以顺利的完成各种组件的融合,而Dubbo缺少很多组件,需要借用第三方或者自己定制。

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

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

 

1.2  通讯协议PK

结论:Dubbo使用RPC通讯协议,Spring Cloud 使用HTTP协议的REST API。dubbo通信速度上略胜Spring Cloud。

性能比较

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


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

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

 

 

1.3 服务调用方式/依赖方式PK

结论:

Dubbo的服务消费方,和服务提供方之间,有抽象接口的强依赖关系,但程序入侵少。

而SpringCloud Netflix的消费方和提供方之间通过Json方式交互,无接口依赖。从解耦方面来看,Springcloud更占优势,为跨平台调用奠定了基础。

 

Dubbo的服务调用方式

interface层:服务接口层,定义了服务对外提供的所有接口
Molel层:服务的DTO对象层,
business层:业务实现层,实现interface接口并且和DB交互
因此需要为每个微服务定义了各自的interface接口,并通过持续集成发布到私有仓库中,调用方应用对微服务提供的抽象接口存在强依赖关系,开发、测试、集成环境都需要严格的管理版本依赖。
通过maven的install & deploy命令把interface和Model层发布到仓库中,服务调用方只需要依赖interface和model层即可。在开发调试阶段只发布Snapshot版本。等到服务调试完成再发布Release版本,通过版本号来区分每次迭代的版本。通过xml配置方式即可方面接入dubbo,对程序无入侵。

 

 

代码示例

“消费者module”想RPC“提供者module”里TickerServiceImpl的方法,需要在“消费者module”定义路径相同的接口名,然后辅以@Reference注解,就能拿到。

 

 

SpringCloud的服务调用方式

Spring Cloud:服务提供方和服务消费方通过json方式交互,因此只需要定义好相关json字段即可,消费方和提供方无接口依赖。通过注解方式来实现服务配置,对于程序有一定入侵。

 

 

代码示例

完全不需要像RPC一样添加同路径名的接口,只要知道所求方法的请求路径和返回值,就能直接通过RestTemplate来访问。消费者 和 提供者 完全解耦!!!

 

二、SpringCloud Netflix v.s SpringCloud Alibaba

2.1 结论

Springcloud Netflix的部分项目停止开源,大部分项目进入了维护模式(停止更新),停更不停用的状态。

Springcloud Alibaba保持开源,正逐渐成为主流;并且搭配了完善的可视化界面,对国内用户的体验较为友好。

推荐使用Springcloud Alibaba

2.2 微服务核心架构要素PK

  SpringCloud Netflix SpringCloud Alibaba
API网关 Zuul(停更)
HTTP,RPC框架 Feign + Ribbon Dubbo
服务注册/发现 Eureka(停更) Nacos
熔断降级 Hystrix(停更) Sentinel
负载均衡(服务端) Ribbon(停更)  
声明式HTTP客户端 Feign(停更)  
配置中心     Nacos
调用链监控    
分布式事务 Seata
消息中间件 RocketMQ

 

2.3 为何抛弃 SpringCloud Netflix

Spring Cloud Netflix 的部分项目停止开源,大部分项目进入了维护模式(停止更新)。进入维护模式意味着什么呢?

  • 进入维护模式意味着Spring Cloud Netflix 将不再开发新的组件了。我们都知道Spring Cloud 版本迭代算是比较快的,因而出现了很多重大ISSUE都还来不及Fix就又推另一个Release了。进入维护模式意思就是目前一直以后一段时间Spring Cloud Netflix提供的服务和功能就这么多了,不在开发新的组件和功能了。以后将以维护和Merge分支Full Request为主。
  • 新组件功能将以其他替代平代替的方式实现

 

SpringCloud的Hoxton版本,和之前的版本相比,用新的组件替换掉了原来大部分的组件,老的组件现在处于 停更不停用 的状况。

详情见下图(× 的表示之前的组件,现在停更了的; 的表示新的替换后的组件):

 

服务注册中心:

Eureka:官方停止更新,并且已经有更好的替代产品了,可以使用,但是官方已经不建议使用了(重度患者)。

Zookeeper:某些老系统,以前是用的Zookeeper + Dubbo,后来做技术升级,结果发现SpringCloud的Eureka停更了,然后就用了最少的技术切换,那么就用了Zookeeper做注册中心。

Consul:go语言开发的,也是一个优秀的服务注册框架,但是使用量较少,风头都被Nacos抢了。

Nacos:来自于SpringCloudAlibaba,在企业中经过了百万级注册考验的,不但可以完美替换Eureka,还能做其他组件的替换,所以强烈建议使用,是学习的重点。

服务调用:

Ribbon:也进入了维护状态,停止更新了,但是Spring官方还在使用(轻度患者)。

LoadBalancer:Spring官方推出的一个新的组件,打算逐渐取代掉Ribbon,但是现在还处于萌芽状态。

服务调用2:

Feign:Netflix 公司产品,也停止更新了。

OpenFeign:Spring社区等不了Netflix更新了,然后就自己做了一个组件,不用Feign了。

服务降级:

Hystrix:官网不推荐使用,但是中国企业中还在大规模使用。

Resilience4J:官网推荐使用,但是国内很少用这个。

Sentienl:来自于SpringCloudAlibaba,在中国企业替换Hystrix的组件,国内强烈建议使用。

服务网关:

Zuul:Netflix 公司产品,公司内部产生分歧,有的人想自己出一个Zuul2。

Zuul2:也是Netflix 公司准备出的产品,但是由于内部分歧,所以Zuul2已经胎死腹中了。

gateway:Spring社区自己出的网关组件,官方隆重介绍和极度推荐的网关服务组件。

服务配置:

Config:目前也在使用,风头被Nacos抢了。

Nacos:来自于SpringCloudAlibaba,后来居上,把Config给替换了。

服务总线:

Bus:SpringCloud原生的服务总线组件,现在风头也被Nacos抢了。

Nacos:来自于SpringCloudAlibaba,后来居上,把Bus给替换了。

 

综上可以看出,Nacos 是重中之重,一个组件就替换掉了原来的几个组件。

 

2.4 为何选择 SpringCloud Alibaba 

 

参考文献

微服务中 Dubbo 和 Spring Cloud 架构技术路线对比: http://www.360doc.com/content/17/1120/08/35874779_705454664.shtml (印象笔记也有)

Spring Cloud Netflix项目进入维护模式 https://blog.csdn.net/u012437781/article/details/85258505

SpringCloud组件的停更和替换说明 https://www.cnblogs.com/y3blogs/p/13276504.html

 

posted on 2021-09-05 17:45  frank_cui  阅读(191)  评论(0编辑  收藏  举报

导航

levels of contents