微服务框架 SpringCloud微服务架构 微服务保护 32 隔离和降级 32.5 熔断策略【慢调用】
创始人
2024-04-21 12:37:35

微服务框架

【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】

微服务保护

文章目录

      • 微服务框架
      • 微服务保护
      • 32 隔离和降级
        • 32.5 熔断策略【慢调用】
          • 32.5.1 熔断策略【慢调用】
          • 32.5.2 案例

32 隔离和降级

32.5 熔断策略【慢调用】

32.5.1 熔断策略【慢调用】

断路器熔断策略有三种:慢调用、异常比例、异常数

  • 慢调用:业务的响应时长(RT response time)大于指定时长的请求认定为慢调用请求。在指定时间内,如果请求数量超过设定的最小数量,慢调用比例大于设定的阈值,则触发熔断。例如:

在这里插入图片描述

解读:RT超过500ms的调用是慢调用,统计最近10000ms内的请求,如果请求量超过10次,并且慢调用比例不低于0.5,则触发熔断,熔断时长为5秒。然后进入half-open状态,放行一次请求做测试。

【不废话、实践看看】

32.5.2 案例

【案例】熔断策略-慢调用

需求:给 UserClient的查询用户接口设置降级规则,慢调用的RT阈值为50ms,统计时间为1秒,最小请求数量为5,失败阈值比例为0.4,熔断时长为5

提示:为了触发慢调用规则,我们需要修改UserService中的业务,增加业务耗时:

【修改controller】

package cn.itcast.user.web;import cn.itcast.user.config.PatternProperties;
import cn.itcast.user.pojo.User;
import cn.itcast.user.service.UserService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;@Slf4j
@RestController
@RequestMapping("/user")
// @RefreshScope
public class UserController {@Autowiredprivate UserService userService;// @Value("${pattern.dateformat}")// private String dateformat;@Autowiredprivate PatternProperties properties;@GetMapping("prop")public PatternProperties properties(){return properties;}@GetMapping("now")public String now(){return LocalDateTime.now().format(DateTimeFormatter.ofPattern(properties.getDateformat()));}/*** 路径: /user/110** @param id 用户id* @return 用户*/@GetMapping("/{id}")public User queryById(@PathVariable("id") Long id,@RequestHeader(value = "Truth", required = false) String truth) throws InterruptedException {if (id == 1){//休眠,触发熔断Thread.sleep(60);}return userService.queryById(id);}
}

重启user 服务

在这里插入图片描述

OK

现在测试访问,看看请求时间

id =1 ,肯定是60ms ↑

在这里插入图片描述

id ≠ 1

在这里插入图片描述

就非常快

在这里插入图片描述

OK,即101 会触发,102 和其他不会触发

在这里插入图片描述

先把之前配的流控规则删掉

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

直接新增

在这里插入图片描述

OK

手动测试…

在这里插入图片描述

一秒5 次,触发熔断【这就是慢调用熔断策略】

上一篇:Redis

下一篇:_001_Zotero入门

相关内容

热门资讯

猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...