一、为什么使用SpringCloud Alibaba
有了spring cloud这个微服务的框架,为什么又要使用spring cloud alibaba这个框架了?
最重要的原因在于spring cloud中的几乎所有的组件都使用Netflix公司的产品,然后在其基础上做了一层封装。然而Netflix的服务发现组件Eureka已经停止更新;而其他的众多组件在2020年停止维护。所以急需其他的一些替代产品,也就是spring cloud alibaba,目前正处于蓬勃发展的态式。
SpringCloud Alibaba真实应用场景
- 大型复杂的系统,例如大型电商系统
- 高并发系统,例如大型门户,秒杀系统
- 需求不明确,且变更很快的系统,例如创业公司业务系统
二、SpringCloud和SpringCloud Alibaba的区别
SpringCloudAlibaba实际上对我们的SpringCloud2.x和1.x实现拓展组件功能。
nacos是分布式配置中心+分布式注册中心=Eureka+config。
研发SpringCloudAlibaba目的是为了推广阿里的产品,如果使用了SpringCloudAlibaba,最好使用alibaba整个体系产品。
SpringCloud 部分组件停止维护和更新,给开发者带来不便。
SpringCloud 部分环境搭建复杂,没有完善的可视化界面,我们需要大量的二次开发和定制。
SpringCloud配置复杂,难以上手,部分配置差别难以区分和合理应用。
早期的SpringCloud的部分组件都已经闭源,不维护了,比如erueka、consol、Feign、zuul
阿里使用过的组件经历了考验,性能强悍,设计合理,现在开源出来给大家用。
成套产品搭配完善的可视化界面给开发运维带来了极大的便利。
搭建简单,学习曲线低。
三、SpringCloudAlibaba都有哪些组件?
1、Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
2、Sentinel:把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
3、RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
4、Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
5、Dubbo:Apache Dubbo™ 是一款高性能 Java RPC 框架。
6、Alibaba Cloud ACM:一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产品。
7、Alibaba Cloud OSS: 阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
8、Alibaba Cloud SchedulerX: 阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。
9、Alibaba Cloud SMS: 覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。
三、版本与兼容性
语义化的版本控制
SpringCloud版本命名