一 服务熔断

1.1 服务熔断降级

Sentinel熔断降级会在调用链路中某个资源出现不稳定状态时(调用超时或者异常比例升高),对这个资源的调用进行限制,让请求快速失败,避免影响到其他资源进而导致级联错误。

当资源被降级后,在接下来的降级时间窗口内,对该资源的调用都自动熔断。(默认抛出DegradeException)

Sentinel的断路器是没有半开状态的;半开状态的系统自动去监测是否请求有异常;如果有异常,则继续打开断路器不可用;没有异常则就关闭断路器恢复使用。

1.2 服务熔断降级常用配置策略

微服务熔断代码 服务熔断策略_分布式

1)RT:平均响应时间,秒级;

平均响应时间超出阈值且在时间窗口内通过的请求>=5,这两个条件同时满足后触发降级:

窗口期过后关闭断路器,则重新能够访问。RT的最大值为4900

2)异常比例:秒级

QPS>=5且异常比例超过阈值时,触发降级;时间窗口结束后,关闭降级。

3)异常数

异常数(分钟统计) 超过阈值时,触发降级;时间窗口结束后,关闭降级。

二  服务熔断案例

2.1 策略1:RT设置

1.首先新增一个请求方法/testD,在方法里设置休眠1秒钟;

微服务熔断代码 服务熔断策略_sentinel_02

2.配置RT

微服务熔断代码 服务熔断策略_断路器_03

 3.不停的刷新/testD接口,当1秒请求的次数大于5(官方给出的默认值要求大于5)且RT设置为300ms给出响应,但是接口方法中设置了休眠1秒,响应时间肯定大于设置阈值300ms,则满足这两个条件,则触发熔断降级机制。2秒的熔断窗口期中,多次访问均处于熔断状态,2秒后熔断关闭

微服务熔断代码 服务熔断策略_断路器_04

 2秒后熔断关闭,访问正常

微服务熔断代码 服务熔断策略_断路器_05

2.2 策略2:异常比例

2.2.1  架构图

微服务熔断代码 服务熔断策略_java_06

 2.2.2 操作

1.设置testD方法中,设置算术异常逻辑

微服务熔断代码 服务熔断策略_java_07

 2.配置

异常出现比例20%,且每秒请求数目大于5,则触发熔断机制,且在熔断的5s时间窗口期内,不能访问服务。

微服务熔断代码 服务熔断策略_微服务熔断代码_08

 3.单独正常访问,报算术异常

微服务熔断代码 服务熔断策略_java_09

4.进行频繁刷新,触发熔断条件,则走熔断机制,报如下提示:

微服务熔断代码 服务熔断策略_分布式_10

 5.窗口期5s过后,再次访问,恢复正常,熔断服务关闭,走接口的正常逻辑,报算术异常

微服务熔断代码 服务熔断策略_分布式_11

2.3 策略3:异常数

异常数:当资源近1分钟的异常数超过阈值之后进行熔断。这里的统计窗口为分钟级别,如果timewindow小于60s,则结束熔断后,仍有可能再次进入熔断。

所以:时间窗口一定要大于等于60s。

1.说明,第一次访问:http://localhost:7005/testE 肯定报错,因为除数不能为0;

2.配置

在1分钟内异常数大于5,则触发熔断降级,在时间窗口70s内,都不能正常访问,超过70s后,再次访问后报算术异常 

微服务熔断代码 服务熔断策略_分布式_12

3.连续访问地址,触发大于5次

 

微服务熔断代码 服务熔断策略_java_13

4.超过70s后,再次访问后报算术异常 

微服务熔断代码 服务熔断策略_java_14