随着Spring Cloud Alibaba的发展,Spring Cloud Alibaba的相关组件逐渐的成熟,对于它的学习和研究已经是java开发人员的趋势。这篇博文主要内容是介绍什么是Spring Cloud Alibaba,Spring Cloud 与Spring Cloud Alibaba的关系,以及我们为什么要学习它,以及畅想Spring Cloud Alibaba未来发展。
在介绍Spring Cloud Alibaba之前,我们先简单的说一下Spring Cloud。
提起微服务,不得不提 Spring Cloud全家桶系列,SpringCloud 是一系列框架的有序集合。Spring Cloud 通过 Spring Boot 风格的封装,屏蔽掉了复杂的配置和实现原理,简化了分布式系统集成设施的开发。Spring Cloud提供了服务治理、服务网关、智能路由、负载均衡、断路器、监控跟踪、分布式消息队列、配置管理等领域的解决方案。
一般来说,Spring Cloud 包含以下组件,主要以 Netflix 开源为主:
官网介绍:
Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。
简单一句话总结: 在Spring Cloud Alibaba的基础上,使用阿里开源的中间件来搭建分布式应用系统。
同 Spring Cloud 一样,Spring Cloud Alibaba 也是一套微服务解决方案,包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。
依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。
作为 Spring Cloud 体系下的新实现,Spring Cloud Alibaba 跟官方的组件或其它的第三方实现如 Netflix, Consul,Zookeeper 等对比,具备了更多的功能:
这幅图是 Spring Cloud Alibaba 系列组件,其中包含了阿里开源组件,阿里云商业化组件,以及集成Spring Cloud 组件。
Nacos
一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
Sentinel
把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
RocketMQ
开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
Dubbo
这个就不用多说了,在国内应用非常广泛的一款高性能 Java RPC 框架。
Seata
阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
Arthas
开源的Java动态追踪工具,基于字节码增强技术,功能非常强大。
作为一家商业公司,阿里巴巴推出 Spring Cloud Alibaba,很大程度上是希望通过抢占开发者生态,来帮助推广自家的云产品。大家可以细品。O(∩_∩)O哈哈~
Alibaba Cloud ACM
一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产品。
Alibaba Cloud OSS
阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
Alibaba Cloud SchedulerX
阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准的定时(基于 Cron 表达式)任务调度服务。
Alibaba Cloud SMS
覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。
Spring Cloud Alibaba 作为整套的微服务解决组件,只依靠目前阿里的开源组件是不够的,更多的是集成当前的社区组件,所以 Spring Cloud Alibaba 可以集成 Zuul,OpenFeign等网关,也支持 Spring Cloud Stream 消息组件。
SpringCloud Alibaba是SpringCloud的子项目,SpringCloud Alibaba符合SpringCloud标准。
SpringCloud与SpringCloud Alibaba的关系,如下图:
一句话总结:Spring Cloud Alibaba是符合Spring Cloud标准的,一套完整的分布式解决方案。
Spring Cloud Alibaba 虽然诞生时间不久,但是背靠大树好乘凉,赖于阿里巴巴强大的技术影响力,已经成为微服务解决方案的重要选择之一。
我看好Spring Cloud Alibaba的原因,如下:
Spring Cloud全家桶系列中众多组件,已经停止更新,例如Eureka,zuul等。并且相关的组件不再主动修改bug,不再发布新版本。对于线上依赖Spring Cloud组件的众多公司不得不,寻找更好的解决方案。
Spring Cloud Alibaba不仅仅整合了当前社区的开源组件,而且在Spring Cloud的基础上,对Spring Cloud的集成已经非常的成熟,能够满足我们对分布式系统开发对公共组件所有的解决方案。
阿里巴巴是国内开源技术领域的最有影响力的公司之一,已经有非常多成功的开源组件,例如:Dubbo、Druid,FastJson,RocketMQ等,再加上阿里不遗余力的推广,社区发展也非常快。众多开源组件都经历过双十一大促的线上考验,能够满足高并发,高性能,高可扩展的需求。
博主会不间断的持续更新这个系列的文章,请大家期待。