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框架的其中一个框架。