浅谈SpringCloud Alibaba和SpringCloud的区别
作者:怪 咖@
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 阿里巴巴的特点:
- 流量控制和服务降级:支持WebServlet、WebFlux、OpenFeign、RestTemplate、Dubbo接入限流降级功能。可以在运行时通过控制台实时修改限流和降流规则,还支持对限流和降流Metrics的监控。
- 服务注册和发现:可以注册服务,客户端可以使用 Spring 管理的 bean,自动集成 Ribbon 发现实例。
- 分布式配置:支持分布式系统的外部化配置,配置变化时自动刷新。
- Rpc Service:扩展 Spring Cloud 客户端 RestTemplate 和 OpenFeign 以支持调用 Dubbo RPC 服务。
- 事件驱动:支持构建与共享消息系统连接的高度可扩展的事件驱动微服务。
- 分布式事务:支持高性能、易用的分布式事务解决方案。
- 阿里云对象存储:海量、安全、低成本、高可靠的云存储服务。支持随时随地在任何应用程序中存储和访问任何类型的数据。
- 阿里云SchedulerX:精准、高可靠、高可用的定时作业调度服务,响应时间秒级。
- 阿里云短信:覆盖全球的短信服务,阿里短信提供便捷、高效、智能的通信能力,帮助企业快速联系客户。
组件:
- Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
- Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
- RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
- Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
- Alibaba Cloud OSS: 阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
- Alibaba Cloud SchedulerX: 阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。
- Alibaba Cloud SMS: 覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。
Spring Cloud Netflix属于cloud集成了人家,而Spring Cloud Alibaba属于是自己维护,但是加入了cloud社区,也就是在cloud官网可以看到。这两个都不是一个普通组件,像gateway和openFeign这些属于一个组件,而Netflix和Alibaba是一套组件,这个关系一定要屡明白!
Cloud 框架上目前有哪些变化呢?
名称 | 之前的最新的 | 目前所替代的 |
注册中心 | Eureka | Consul(spring的)、Nacos(Alibaba的) |
配置中心 | Config(spring的) | Consul(spring的)、Nacos(Alibaba的) |
网 关 | Zuul | SpringCloud Gateway(spring的) |
负载均衡 | Ribbon | Loadbalancer (spring的) |
熔断降级 | Hystrix | Sentinel(Alibaba的) |
服务调用 | Feign | OpenFeign(spring的) |
其中Eureka + Ribbon + Feign + Hystrix + Zuul
都属于Netflix 的 Nacos
和 Sentinel
属于是Cloud Alibaba的,其他均属于spring cloud自己的,而spring cloud属于是spring框架的其中一个框架。
到此这篇关于浅谈SpringCloud Alibaba和SpringCloud的区别的文章就介绍到这了,更多相关浅谈SpringCloud Alibaba内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!