Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性简化了分布式系统的开发,如服务发现、服务配置、负载均衡、断路器、智能路由、微代理、控制总线等。
Spring Cloud包含的项目:
- Spring Cloud Config:配置管理工具,使用版本控制系统来存储配置信息,可以实现应用配置的外部化管理。
- Spring Cloud Netflix:整合各种Netflix组件(Eureka, Hystrix, Zuul, Archaius等)。
- Spring Cloud Bus:事件、消息总线,用于传输集群中的状态变化,比如配置变化。
- Spring Cloud for Cloudfoundry:集成Cloudfoundry平台。
- Spring Cloud Open Service Broker:为基于Spring的服务提供者提供一个简单的方式实现Open Service Broker API的API。
- Spring Cloud Security:提供在微服务中实现认证和授权的工具。
- Spring Cloud Consul:集成Hashicorp Consul作为服务发现和配置管理。
- Spring Cloud Zookeeper:集成Zookeeper用于服务发现。
- Spring Cloud Sleuth:日志收集工具,跟踪微服务架构中的请求流。
- Spring Cloud Task:为短生命周期的微服务提供管理,比如批处理作业。
- Spring Cloud Gateway:作为路由器,提供路由、过滤等功能。
- Spring Cloud OpenFeign:提供使用Spring MVC注解的Web服务客户端。
- Spring Cloud Stream:数据流操作开发包,简化消息的发送和接收。
- Spring Cloud Task:为短生命周期的微服务提供管理,比如批处理作业。
- Spring Cloud Wavefront:整合Wavefront来收集监控数据。
Spring Cloud版本命名规则:版本名称是基于Spring Boot版本,并且通常以带有SR
(Service Release)的数字结束,比如:Hoxton.SR10。
Spring Cloud的主要模块和子项目:
- Spring Cloud Config:配置管理工具。
- Spring Cloud Netflix:整合各种Netflix组件。
- Eureka:服务发现。
- Hystrix:断路器,提供熔断机制,防止系统雪崩。
- Ribbon:客户端负载均衡。
- Feign:声明式Web服务客户端。
- Zuul:API网关,提供路由,过滤等功能。
- Archaius:配置管理库。
以上是Spring Cloud的基本介绍和主要模块,它提供了一套完整的微服务解决方案。