一、基本概念
Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。
Spring Cloud并没有重复制造轮子,它只是将各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
常见的组件包括:
- Eureka:服务治理组件,可以实现服务的自动注册、自动发现等功能。
- Ribbon:客户端负载均衡组件,可以实现请求在多个服务实例之间的负载均衡。
- Feign:声明式 REST 客户端,可将 REST 接口转换为 Java 接口,更容易地发起 REST 调用。
- Hystrix:断路器组件,用于实现服务的容错和快速失败等机制。
- Zuul:网关组件,可以实现请求的路由、负载均衡、请求过滤等功能。
- Config:配置中心组件,可以集中管理微服务的配置信息,并且支持动态刷新。