java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > 浅谈SpringCloud Alibaba

浅谈SpringCloud Alibaba和SpringCloud的区别

作者:怪 咖@

这篇文章主要介绍了浅谈SpringCloud Alibaba和SpringCloud的区别,Spring Cloud Netflix框架也属于Spring Cloud,但是Netflix并不是由spring来进行开发的,需要的朋友可以参考下

Spring Cloud Netflix 和 Spring Cloud 是什么关系?

Spring Cloud Netflix框架也属于Spring Cloud,但是Netflix并不是由spring来进行开发的。而是由Netflix(Nasdaq NFLX) 美国奈飞公司开发的。在某一时间段进行开源了出来,然后spring官网认为他的微服务架构体系挺完善,然后直接给集成到了cloud社区当中。所谓集成也就是二次封装,封装了Netflix框架各个组件的starter,于是乎我们需要哪个组件就引入哪个组件的starter,用少量的配置便可以快速上手。

Netflix源码社区:https://github.com/Netflix

Netflix其实开源的项目有很多,而spring呢,也是将Netflix当中的五大组件给集成到了cloud当中,五大组件分别是Eureka + Ribbon + Feign + Hystrix + Zuul。其实在没了解过历史的情况下,很多人都会以为这五个组件是cloud提供的,并且认为cloud是微服务的一站式解决方案,其实真正一站式的是Netflix,毫不夸张的讲就是Netflix体系成就了现在的cloud!

这五个组件构造了我们所谓的一站式微服务架构,而微服务架构完全是由注册中心、负载均衡、远程调用、熔断器、网关来组成的。正因为这五个组件也彻底将Java引入到了现在人人皆知的微服务架构,他更像是一种框架发展趋势。

组件名称组件作用
Eureka注册中心,服务注册、发现等
Ribbon负载均衡,多服务时做负载
Feign服务间内部调用
Hystrix熔断器,服务熔断、降级
Zuul服务网关,所有外部请求经过网关进行过滤转发(路由+过滤+转发)

闲聊: 有的公司甚至根本都涉及不到高并发,但是也会毫不犹豫的使用微服务架构。其实我 个人感觉哈,如果项目特别小的情况下,单体springboot项目其实就足够了,没必要去盲目跟风。当然要是奔着学习而工作的,使用新架构也没有任何毛病。

注意: 在面试的时候经常会问Netflix的五大组件,所以我认为还是有必要学习一哈的。

为什么有了Spring Cloud又出来个Spring Cloud Alibaba呢?

Spring Cloud Netflix的五个组件其实完全足够开发一套成熟的微服务架构,但是为什么又出来个 Spring Cloud Alibaba呢?

原因:2018年12月cloud官网对外宣布: https://spring.io/blog/2018/12/12/spring-cloud-greenwich-rc1-available-now

其实在cloud对外宣布前,Netflix的很多产品已经早就出去停更状态。而cloud也没有任何办法,例如zuul停更,cloud一直等着他更新等不来,于是直接自己开发了一个网关gateway。还有Feign,cloud直接开发了个openFeign。

在这里插入图片描述

这个是官网18年12月发出的框架替代:

在这里插入图片描述

而Alibaba在Netflix停更阶段,开发出了自己的微服务组件,Nacos注册中心和Sentinel熔断限流组件。并且成功于2018.10.31,Spring Cloud Alibaba 正式入驻了 Spring Cloud 官方孵化器,并在 Maven 中央库发布了第一个版本。这样一来cloud也算是松了一口气。

在这里插入图片描述

当然商人之间肯定有利益交易,Spring Cloud Alibaba也是利用spring官网来推广自己的云产品。不管人家推荐不推荐,只要开源出来了,我认为就是值得我们学习的!并且说真心话,Nacos注册中心不输于任何现有的注册中心。Sentinel熔断器和Hystrix熔断器那就更不用提了,简直一个天上一个地下。当然Netflix属于老产品,Alibaba属于借助人家的思想而后开发的。所以本身也没有可比性。

在这里插入图片描述

Spring Cloud Alibaba都有哪些功能呢?

源码:https://github.com/alibaba/spring-cloud-alibaba SpringCloud Alibaba

官网:https://spring.io/projects/spring-cloud-alibaba#overview

github中文文档:https://github.com/alibaba/spring-cloud-alibaba/blob/2.2.x/README-zh.md

也可以通过官网来看文档:

在这里插入图片描述

使用Spring Cloud Alibaba,您只需添加一些注解和配置,您的应用程序就可以使用阿里巴巴的分布式解决方案,并通过阿里巴巴中间件构建您自己的分布式系统。

Spring Cloud 阿里巴巴的特点:

组件:

Spring Cloud Netflix属于cloud集成了人家,而Spring Cloud Alibaba属于是自己维护,但是加入了cloud社区,也就是在cloud官网可以看到。这两个都不是一个普通组件,像gateway和openFeign这些属于一个组件,而Netflix和Alibaba是一套组件,这个关系一定要屡明白!

Cloud 框架上目前有哪些变化呢?

名称之前的最新的目前所替代的
注册中心EurekaConsul(spring的)、Nacos(Alibaba的)
配置中心Config(spring的)Consul(spring的)、Nacos(Alibaba的)
网 关ZuulSpringCloud Gateway(spring的)
负载均衡RibbonLoadbalancer (spring的)
熔断降级HystrixSentinel(Alibaba的)
服务调用FeignOpenFeign(spring的)

其中Eureka + Ribbon + Feign + Hystrix + Zuul都属于Netflix 的 NacosSentinel属于是Cloud Alibaba的,其他均属于spring cloud自己的,而spring cloud属于是spring框架的其中一个框架。

到此这篇关于浅谈SpringCloud Alibaba和SpringCloud的区别的文章就介绍到这了,更多相关浅谈SpringCloud Alibaba内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文