1、SpringCloud是什么?

SpringCloud是一系列框架的集合,集成SpringBoot,提供很多优秀服务:服务发现和注册,统一配置中心, 负载均衡,网关, 熔断器等的一个微服务治理框架.

2、SpringCloud的优势?(了解)

因为SpringCloud源于Spring,所以它的质量,稳定性,持续性都是可以保证的。
SpringCloiud热支持SpringBoot框架,就可以提高开发效率,能够实现需求。
SpringCloud更新很快,后期支持很给力。
SpringCloud可以用来开发微服务。

3、SpringCloud有哪些核心组件?(必会)

Eureka:注册中心, 服务注册和发现
Ribbon:负载均衡, 实现服务调用的负载均衡
Hystrix:熔断器
Feign:远程调用
Zuul:网关

(1)Eureka

提供服务注册和发现, 是注册中心. 有两个组件: Eureka服务端和Eureka客户端
Eureka服务端: 作为服务的注册中心, 用来提供服务注册, 支持集群部署.
Eureka客户端: 是一个java客户端, 将服务注册到服务端, 同事将服务端的信息缓存到本地, 客户端和服务端定时交互.
原理:
image.png
Eureka-Server:就是服务注册中心(可以是一个集群),对外暴露自己的地址。
提供者:启动后向Eureka注册自己信息(地址,服务名称等),并且定期进行服务续约
消费者:服务调用方,会定期去Eureka拉取服务列表,然后使用负载均衡算法选出一个服务进行调用。
心跳(续约):提供者定期通过http方式向Eureka刷新自己的状态

(2)Ribbon

Ribbon是Netflix发布的云中服务开源项目. 给客户端提供负载均衡, 也就是说Ribbon是作用在消费者方的.
简单来说, 它是一个客户端负责均衡器, 它会自动通过某种算法去分配你要连接的机器.
SpringCloud认为Ribbon这种功能很好, 就对它进行了封装, 从而完成负载均衡.
Ribbon默认负责均衡策略是轮询策略.

(3)Hystrix熔断器

有时候可能是网络问题, 一些其它问题, 导致代码无法正常运行,这是服务就挂了, 崩溃了. 熔断器就是为了解决无法正常访问服务的时, 提供的一种解决方案.
解决因为一个服务崩溃而引起的一系列问题, 使问题只局限于这个服务中,不会影响其他服务.
Hystrix提供了两种功能, 一种是服务降级, 一种是服务熔断.

1. 服务降级原理

Hystrix为每个服务分配了小的线程池, 当用户发请求过来, 会通过线程池创建线程来执行任务, 当创建的线程池已满或者请求超时(这里和多线程线程池不一样,不存在任务队列), 则启动服务降级功能.
降级指的请求故障时, 不会阻塞, 会返回一个友好提示(可以自定义, 例如网站维护中请稍后重试), 也就是说不会影响其他服务的运行.

2.服务熔断原理

image.png
状态机有3个状态:
Closed:关闭状态(断路器关闭),所有请求都正常访问
Open:打开状态(断路器打开),所有请求都会被降级。Hystix会对请求情况计数,当一定时间内失败请求百分比达到阈值,则触发熔断,断路器会完全关闭。默认失败比例的阈值是50%,请求次数最少不低于20次
Half Open:半开状态,open状态不是永久的,打开后会进入休眠时间(默认是5S)。随后断路器会自动进入半开状态。此时会释放1次请求通过,若这个请求是健康的,则会关闭断路器,否则继续保持打开,再次进行5秒休眠计时。

(4)Feign: 远程调用组件

后台系统中, 微服务和微服务之间的调用可以通过Feign组件来完成.
Feign组件集成了Ribbon负载均衡策略(默认开启的, 使用轮询机制), Hystrix熔断器(默认关闭的, 需要通过配置文件进行设置开启) 被调用的微服务需要提供一个接口, 加上@FeignClient(“url”)注解
调用方需要在启动类上加上@EnableFeignClients, 开启Feign组件功能.

(5)Zuul: 路由/网关

对于项目后台的微服务系统, 每一个微服务都不会直接暴露给用户来调用的, 但是如果用户知道了某一个服务的ip:端口号:url:访问参数, 就能直接访问你. 如果再是恶意访问,恶意攻击, 就会击l 垮后台微服务系统.因此, 需要一个看大门的大boss, 来保护我们的后台系统.
Zuul类似Nginx, 反向代理功能. 用户访问服务, 首先会到Zuul中心, Zuul去Eureka中拉取服务, 获取服务列表, 获取具体的地址, 通过具体的地址去访问目标微服务.
Zuul提供了过滤和路由两个功能, 过滤可以分配权限, 允许谁可以访问谁不可以访问, 路由则是去Eureka拉取服务提访问地址.
Zuul网关也继承了Ribbon负载均衡和Hystix熔断机制.