springcloud是微服务架构的集大成者,将一系列优秀的组件进行了整合。
1,服务发现 Netflix Eureka
实现服务的管理(服务的注册与发现)
2,客户端的负载均衡 Netflix Ribbon(Feign)
Ribbon(Feign) 主要提供客户端的软件负载均衡算法,是一个基于HTTP和TCP的客户端负载均衡工具,通过springcloud的封装,使用Rest模板来调用服务。
Feign是基于Ribbon实现的
3,Hystrx 熔断器
断路器,保护系统,控制故障范围
熔断的条件:
- 服务宕机
- 服务抛异常
- 服务超时
4, zuul 网关
路由,限流,降级,安全控制,服务的聚合
5,config 配置管理
可以通过这个组件实现对每个服务内的配置文件进行统一管理。