Spring Cloud是一系列框架的有序集合,它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发。Spring Cloud提供了微服务架构开发所需的多种组件和工具,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。它并没有重复制造轮子,而是将各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装,屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
Spring Cloud Alibaba 在使用时通常需要依赖 Spring Cloud 的依赖包。这是因为 Spring Cloud Alibaba 是 Spring Cloud 生态系统中的一个子项目,它提供了对阿里巴巴开源组件(如 Nacos、Sentinel、RocketMQ 等)的集成支持。因此,为了保持项目依赖的完整性和一致性,当使用 Spring Cloud Alibaba 时,往往也需要包含 Spring Cloud 的相关依赖。
具体来说,Spring Cloud Alibaba 的项目通常会通过 Maven 或 Gradle 等构建工具来管理依赖。在 pom.xml(Maven)或 build.gradle(Gradle)文件中,会明确指定所需的依赖项,包括 Spring Cloud Alibaba 的启动器(starter)和 Spring Cloud 的依赖管理(dependency management)。
com.alibaba.cloud
spring-cloud-alibaba-dependencies
版本号
pom
import
org.springframework.cloud
spring-cloud-dependencies
版本号
pom
import
注意spirng-cloud和spring-cloud-alibaba版本号的适配问题
cloud (Hoxton.SR1) ---- cloud-alibaba(2.1.0.RELEASE)
com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-discovery
com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-config
Spring Cloud 只提供抽象模式的定义不提供官方稳定实现,开发者只能寻求类似 Netflix、Alibaba、Azure 等不同厂商的实现套件,而每个厂商支持的完善度、稳定性、活跃度各异
Sping Cloud和Spring Cloud alibaba的关系相当于和Sping Cloud和Netflix的关系