一天和我合租的兄弟闲聊,听到他说他们公司在使用 Spring Cloud Alibaba微服务框架,当时听到这个名字我是一脸懵逼,阿里巴巴什么时候和spring公司有一腿了?尴尬的一批。唉,看来程序员果然是一个终身学习的职业呀,一日不学,就脱离世界了。
今天我们就了解一下Spring Cloud Alibaba,做个简单入门。这篇博文主要内容是介绍什么是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 等对比,具备了更多的功能:
服务限流降级:默认支持 WebServlet、WebFlux, OpenFeign、RestTemplate、Spring Cloud Gateway, Zuul, Dubbo 和 RocketMQ 限流降级功能的接入,可以在运行时通过控制台实时修改限流降级规则,还支持查看限流降级 Metrics 监控。
❤ 服务注册与发现:适配 Spring Cloud 服务注册与发现标准,默认集成了 Ribbon 的支持。
❤ 分布式配置管理:支持分布式系统中的外部化配置,配置更改时自动刷新。
❤ 消息驱动能力:基于 Spring Cloud Stream 为微服务应用构建消息驱动能力。
❤ 分布式事务:使用 @GlobalTransactional 注解, 高效并且对业务零侵入地解决分布式事务问题。。
❤ 阿里云对象存储:阿里云提供的海量、安全、低成本、高可靠的云存储服务。支持在任何应用、任何时间、任何地点存储和访问任意类型的数据。
❤ 分布式任务调度:提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。同时提供分布式的任务执行模型,如网格任务。网格任务支持海量子任务均匀分配到所有 Worker(schedulerx-client)上执行。
❤ 阿里云短信服务:覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。
这幅图是 Spring Cloud Alibaba 系列组件,其中包含了阿里开源组件,阿里云商业化组件,以及集成Spring Cloud 组件。
一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
这个就不用多说了,在国内应用非常广泛的一款高性能 Java RPC 框架。
阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
开源的Java动态追踪工具,基于字节码增强技术,功能非常强大。
作为一家商业公司,阿里巴巴推出 Spring Cloud Alibaba,很大程度上是希望通过抢占开发者生态,来帮助推广自家的云产品。大家可以细品。O(∩_∩)O哈哈~
一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产品。
阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准的定时(基于 Cron 表达式)任务调度服务。
覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。
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等,再加上阿里不遗余力的推广,社区发展也非常快。众多开源组件都经历过双十一大促的线上考验,能够满足高并发,高性能,高可扩展的需求。
今天只是了解一下,有时间的话博主会再学习一下Spring Cloud Alibaba,再更新一些关于它的文章,敬请期待。