【微服务】Sentinel(熔断降级,热点限流)

文章目录

    • 1.熔断降级
        • 1.基本介绍
          • 1.线程堆积引出熔断降级
          • 2.示意图
          • 3.熔断,降级,限流三者之间的关系
        • 2.熔断降级策略(以分钟为基本单位)
          • 1.慢调用比例
          • 2.异常比例
          • 3.异常数
        • 3.熔断降级实例—慢调用比例
          • 1.需求分析
          • 2.com/sun/springcloud/controller/MemberController.java 新增接口t3并休眠300ms
          • 3.具体配置
            • 1.重启10004微服务
            • 2.查看注册情况
            • 3.浏览器输入http://localhost:10004/t3发送请求
            • 4.Sentinel点击降级
            • 5.降级规则配置
          • 4.测试
            • 1.一秒超过五次请求http://localhost:10004/t3会发生熔断降级
            • 2.等待10s,再次请求,虽然还是慢调用,但是小于最小请求数,所以不会发生熔断
        • 5.熔断降级实例—异常比例
          • 1.需求分析
          • 2.com/sun/springcloud/controller/MemberController.java 新增接口t4并出现异常返回error
          • 3.具体配置
            • 1.重启10004微服务
            • 2.查看注册情况
            • 3.浏览器输入http://localhost:10004/t4
            • 4.Sentinel点击降级
            • 5.具体配置
          • 4.测试
            • 1.一秒超过五次请求 http://localhost:10004/t4,发生熔断降级
            • 2.五秒之后再次发送请求,降级解除
        • 6.熔断降级实例—异常数
          • 1.需求分析
          • 2.还是使用掐面的t4接口即可
          • 3.具体配置
          • 4.测试
            • 1.一秒超过五次请求 http://localhost:10004/t4,由于每发生熔断降级
            • 2.五秒之后再次发送请求,降级解除
    • 2.热点限流
        • 1.基本介绍
          • 1.引出热点限流
          • 2.示意图
          • 3.上图解读
        • 2.需求分析
        • 3.具体配置
          • 1.10004微服务的controller增加两个接口
            • 被热点限流的接口
            • 处理热点限流的接口
          • 2.重启10004微服务,并启动Nacos和Sentinel
          • 3.浏览器输入 http://localhost:10004/news?id=1&type=%E5%8A%A8%E7%89%A9
          • 4.Sentinel查看热点接口
          • 5.点击热点,进行基本配置
          • 6.保存后点击热点规则,编辑刚才的规则
          • 7.点击高级选项,对参数的具体值进行额外配置
        • 4.测试
          • 1.浏览器快速访问 http://localhost:10004/news?id=1&type=%E5%8A%A8%E7%89%A9 会出现热点限流
          • 2.快速访问 http://localhost:10004/news?id=2&type=%E5%8A%A8%E7%89%A9 不会出现热点限流
        • 5.注意事项
          • 1.热点参数可以设置多个值进行限流
          • 2.处理热点限流的方法的返回值需要与被处理的方法相同
    • 3.系统规则
        • 1.基本介绍
          • 1.引出系统规则
          • 2.介绍
        • 2.系统规则实例
          • 1.需求分析
          • 2.新增系统规则
          • 3.进行配置
          • 4.测试
            • 浏览器快速访问 http://localhost:10004/t2(或者其他任意的资源) 都会进行热点限流
    • 4.全局限流处理类
        • 1.需求分析
        • 2.具体实现
          • 1.编写全局限流处理类
          • 2.编写一个接口进行测试
          • 3.测试
            • 1.重启10004模块
            • 2.配置system接口的限流,这里就配置一个热点限流
            • 3.浏览器快速访问 http://localhost:10004/system?id=test
    • 5.fallback(统一处理java异常)
        • 1.需求分析
        • 2.具体实现
          • 1.修改system接口,每五次抛出异常
          • 2.编写全局异常处理类
          • 3.system接口使用全局异常处理类处理异常
          • 4.测试
            • 1.打开nacos和sentinel
            • 2.重启10004微服务
            • 3.浏览器访问一下http://localhost:10004/system?id=test
            • 4.Sentinel配置限流,这里就配置一个QPS流量控制
            • 5.目前情况分析
            • 6.访问五次 http://localhost:10004/system?id=test 成功交给全局异常处理类来处理

1.熔断降级

1.基本介绍
1.线程堆积引出熔断降级

image-20240329104355325

2.示意图

image-20240329105626479

3.熔断,降级,限流三者之间的关系

image-20240329105426279

2.熔断降级策略(以分钟为基本单位)
1.慢调用比例
  • 进行熔断的条件是:慢调用的比例达到阈值,QPS大于最小请求数
  • 待超过熔断时长后,如果还是满足熔断条件(慢调用的比例达到阈值,QPS大于最小请求数),则会继续进行熔断

image-20240329110452910

2.异常比例
  • 进行熔断的条件是:异常比例达到阈值,QPS大于最小请求数
  • 待超过熔断时长后,如果还是满足熔断条件(异常比例达到阈值,QPS大于最小请求数),则会继续进行熔断

image-20240329112148590

3.异常数
  • 进行熔断的条件是:异常数达到阈值,QPS大于最小请求数
  • 待超过熔断时长后,如果还是满足熔断条件(异常数达到阈值,QPS大于最小请求数),则会继续进行熔断

image-20240329112510279

3.熔断降级实例—慢调用比例
1.需求分析

image-20240329112705700

2.com/sun/springcloud/controller/MemberController.java 新增接口t3并休眠300ms

image-20240329113359178

3.具体配置
1.重启10004微服务

image-20240329113533774

2.查看注册情况

image-20240329113611668

3.浏览器输入http://localhost:10004/t3发送请求

image-20240329113644817

4.Sentinel点击降级

image-20240329113718423

5.降级规则配置
  • 这样当每秒钟的请求数大于5,并且每分钟只要有一个是慢调用就进行熔断降级

image-20240329114118368

4.测试
1.一秒超过五次请求http://localhost:10004/t3会发生熔断降级

image-20240329114323785

2.等待10s,再次请求,虽然还是慢调用,但是小于最小请求数,所以不会发生熔断

image-20240329115141664

5.熔断降级实例—异常比例
1.需求分析

image-20240329131043620

2.com/sun/springcloud/controller/MemberController.java 新增接口t4并出现异常返回error

image-20240329131230071

3.具体配置
1.重启10004微服务

image-20240329131456261

2.查看注册情况

image-20240329131528454

3.浏览器输入http://localhost:10004/t4

image-20240329131620416

4.Sentinel点击降级

image-20240329131647299

5.具体配置
  • 这样配置表示当每秒钟的请求数达到5,并且**每分钟异常的比例大于20%**则会出现熔断降级

image-20240329131736371

4.测试
1.一秒超过五次请求 http://localhost:10004/t4,发生熔断降级

image-20240329131849384

2.五秒之后再次发送请求,降级解除

image-20240329131959017

6.熔断降级实例—异常数
1.需求分析

image-20240329132810897

2.还是使用掐面的t4接口即可
3.具体配置
  • 这样,当吗,每秒钟的请求数到达5,并且每分钟异常数量大于5,则会进行熔断降级

image-20240329132944371

4.测试
1.一秒超过五次请求 http://localhost:10004/t4,由于每发生熔断降级

image-20240329131849384

2.五秒之后再次发送请求,降级解除

image-20240329131959017

2.热点限流

1.基本介绍
1.引出热点限流

image-20240329134028382

2.示意图

image-20240329134542514

3.上图解读

image-20240329134610173

2.需求分析

image-20240329134928822

3.具体配置
1.10004微服务的controller增加两个接口
被热点限流的接口
  • 使用@SentinelResource注解来制定被热点限流的接口以及处理热点限流的接口
    /*** 测试热点限流* @param id* @param type* @return*/@GetMapping("/news")@SentinelResource(value = "news", blockHandler = "hot") // value为资源名可以任意指定,blockHandler为限流处理public String news(@RequestParam("id") String id, @RequestParam("type") String type) {return "id=" + id + " type=" + type;}
处理热点限流的接口
  • 接受的参数需要与被热点限流的接口的参数一致,并且有一个处理异常的参数
    /*** 热点限流处理* @param id 与news方法的参数一致* @param type 与news方法的参数一致* @param blockException 限流处理的异常* @return 注意:这里的返回值类型要与news方法的返回值类型一致*/public String hot(String id, String type, BlockException blockException) {return "id" + id + "type" + type + "热点限流处理";}
2.重启10004微服务,并启动Nacos和Sentinel
3.浏览器输入 http://localhost:10004/news?id=1&type=%E5%8A%A8%E7%89%A9

image-20240329144442569

4.Sentinel查看热点接口

image-20240329144621993

5.点击热点,进行基本配置
  • 这个配置表示对参数id进行热点限流,只要每秒请求次数超过2就触发限流

image-20240329144934949

6.保存后点击热点规则,编辑刚才的规则

image-20240329145007319

7.点击高级选项,对参数的具体值进行额外配置

image-20240329151348982

4.测试
1.浏览器快速访问 http://localhost:10004/news?id=1&type=%E5%8A%A8%E7%89%A9 会出现热点限流
  • 原因是对参数id设置了热点限流的触发条件为每秒请求数为2

image-20240329151437389

2.快速访问 http://localhost:10004/news?id=2&type=%E5%8A%A8%E7%89%A9 不会出现热点限流
  • 原因是对参数id=2设置了热点限流的触发条件为每秒请求数为100

5.注意事项
1.热点参数可以设置多个值进行限流

image-20240329151708068

2.处理热点限流的方法的返回值需要与被处理的方法相同

3.系统规则

1.基本介绍
1.引出系统规则

image-20240329152555753

2.介绍
  • 简单来说这个系统规则就是对整个系统的所有资源进行统一管理,共享一套限流规则

image-20240329153222053

2.系统规则实例
1.需求分析

image-20240329153902556

2.新增系统规则

image-20240329154220628

3.进行配置
  • 这样配置就表示,整个系统的每秒请求数超过2就会进行限流

image-20240329154301245

4.测试
浏览器快速访问 http://localhost:10004/t2(或者其他任意的资源) 都会进行热点限流

image-20240329154704800

4.全局限流处理类

1.需求分析

image-20240329154954350

2.具体实现
1.编写全局限流处理类
  • 需要注意:方法必须是static,并且参数类型和返回的类型必须与被处理的方法一致
package com.sun.springcloud.handler;import com.alibaba.csp.sentinel.slots.block.BlockException;/*** Description: 全局限流处理器,方法必须是static** @Author sun* @Create 2024/3/29 16:04* @Version 1.0*/
public class GlobalBlockHandler {/*** 全局限流处理器** @param id 传入的参数* @param e  异常* @return 返回的结果,必须与被处理的方法返回值一致*/public static String blockHandler(String id, BlockException e) {return "GlobalBlockHandler " + id + " 服务不可用";}
}
2.编写一个接口进行测试
    /*** 全局限流测试* @return*/@GetMapping("/system")//  @SentinelResource 注解中的value值为资源名 名字任意,blockHandlerClass为全局限流处理类,blockHandler为处理方法@SentinelResource(value = "system", blockHandlerClass = GlobalBlockHandler.class, blockHandler = "blockHandler")public String system(@RequestParam(value = "id", required = false) String id) {return "id" + id + "全局限流未激活";}
3.测试
1.重启10004模块

image-20240329161430407

2.配置system接口的限流,这里就配置一个热点限流

image-20240329161744272

3.浏览器快速访问 http://localhost:10004/system?id=test

image-20240329161901203

5.fallback(统一处理java异常)

1.需求分析

image-20240329162600010

2.具体实现
1.修改system接口,每五次抛出异常
    private int count = 0;/*** 全局限流测试* @return*/@GetMapping("/system")//  @SentinelResource 注解中的value值为资源名 名字任意,blockHandlerClass为全局限流处理类,blockHandler为处理方法@SentinelResource(value = "system", blockHandlerClass = GlobalBlockHandler.class, blockHandler = "blockHandler",fallbackClass = GlobalFallbackHandler.class, fallback = "fallbackHandlerMethod1")public String system(@RequestParam(value = "id", required = false) String id) {// 每调用5次就抛出异常if (++ count % 5 == 0) {throw new RuntimeException("出现异常!!!");}return "id" + id + "全局限流未激活";}
2.编写全局异常处理类
  • 方法需要是static
  • 参数类型和返回类型与被处理的方法类型一致
package com.sun.springcloud.handler;/*** Description: 全局异常处理类,所有的方法都要是静态方法,参数类型和返回值类型也要与被处理的方法返回值相同** @Author sun* @Create 2024/3/29 16:33* @Version 1.0*/
public class GlobalFallbackHandler {public static String fallbackHandlerMethod1(String id, Throwable throwable) {return "fallback处理异常!" + "id:" + id;}
}
3.system接口使用全局异常处理类处理异常
  • 新增两个属性,一个是全局异常处理类的Class对象,一个是处理异常的方法

image-20240329163824828

4.测试
1.打开nacos和sentinel
2.重启10004微服务
3.浏览器访问一下http://localhost:10004/system?id=test
4.Sentinel配置限流,这里就配置一个QPS流量控制

image-20240329164403683

5.目前情况分析
  • 正常情况:每秒请求数不超过2
  • 限流情况:每秒请求数超过2,被全局限流处理类中的方法处理
  • 异常情况:每5次抛出一次异常,交给全局异常处理器处理
6.访问五次 http://localhost:10004/system?id=test 成功交给全局异常处理类来处理

image-20240329170349994

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/578018.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis发布订阅和事务管理

目录 一、发布订阅 1.1 发布订阅简单介绍 1.2 相关命令 二、事务管理 2.1 介绍 2.2 Multi、Exec、discard 2.3 示例 2.4事务的错误处理 2.5 事务的冲突问题 2.5.1 悲观锁 2.5.2 乐观锁 2.5.3 事务解决冲突--WATCH 2.5.4 unwatch 2.6 Redis事务的三个特性 一、发布订…

[flink 实时流基础]源算子和转换算子

文章目录 1. 源算子 Source1. 从集合读2. 从文件读取3. 从 socket 读取4. 从 kafka 读取5. 从数据生成器读取数据 2. 转换算子基本转换算子(map/ filter/ flatMap) 1. 源算子 Source Flink可以从各种来源获取数据,然后构建DataStream进行转换…

Git——分布式版本控制工具详解

一、了解Git基本概念 (o)git github gitee的区别 (一)开发中的实际场景 (二)版本控制器的方式 1、集中式版本控制工具 集中式版本控制工具,版本库是集中存放在中央服务器的,team里…

如何检查电脑的最近历史记录?这里提供详细步骤

如果你怀疑有人在使用你的计算机,并且你想查看他们在做什么,下面是如何查看是否有访问内容的痕迹。 如何检查我的计算机的最近历史记录 要检查计算机的最近历史记录,应该从web浏览器历史记录开始,然后移动到文件。但是,可以修改或删除浏览器历史记录,也可以隐藏Windows…

Qt 图片预览(等比例显示、放大、缩小、平移图像)显示

使用Qt的Painter绘制图像并显示,根据窗口的大小计算图片显示的尺寸,并可以对图片放大和缩小的显示,还可以对已经放大了的图片进行平移预览的操作。 效果如下: 使用函数 painter.translate() 对画布进行平移操作。使用函数 painte…

Linux 系统快速安装 MySQL数据库(新手版)

Linux 系统快速安装 MySQL数据库(新手版) 1.删除原有的mariadb,不然mysql装不进去 查询MAriaDB命令 rpm -qa|grep mariadb 删除 rpm -e --nodeps mariadb-libs-5.5.60-1.el7_5.x86_64 (yum -y remove mysql 如需要…

python爬虫之selenium4使用(万字讲解)

文章目录 一、前言二、selenium的介绍1、优点:2、缺点: 三、selenium环境搭建1、安装python模块2、selenium4新特性3、安装驱动WebDriver驱动选择驱动安装和测试 基础操作1、属性和方法2、单个元素定位通过id定位通过class_name定位一个元素通过xpath定位…

CTK插件框架学习-插件注册调用(03)

CTK插件框架学习-新建插件(02)https://mp.csdn.net/mp_blog/creation/editor/136923735 一、CTK插件组成 接口类:对外暴露的接口,供其他插件调用实现类:实现接口内的方法激活类:负责将插件注册到CTK框架中 二、接口、插件、服务…

spring-boot之接口文档Swagger配置使用

Swagger 前后端分离 Vue SpringBoot 后端时代:前端只用管理静态页面; html> 后端。模板引擎JSP >后端是主力 前后端分离式时代: ●后端:后端控制层,服务层,数据访问层[后端团队] ●前端:前端控制层,视图层[前端团队] 。伪造后端数据,…

List操作add,clear,addall报错UnsupportedOperationException的解决办法

ArrayList和Arrays.ArrayList是两码事 ArrayList 支持 add,clear,addall Arrays.ArrayList不支持add,clear,addall 这个方法的使用时候,传递的数组必须是对象数组,而不是基本数据类型 JDK源码 /** *返回由…

SAMRTFORMS 转换PDF 发送邮件

最终成果: *&---------------------------------------------------------------------**& Report ZLC_FIND_EXIT*&---------------------------------------------------------------------**&根据T-CODE / 程序名查询出口、BADI增强*&-------…

钉钉 AI 升级多种功能;智谱AI PC智能助手发布;百度回应与苹果合作

▶ 钉钉 AI 升级上线多种功能 3 月 28 日,钉钉 AI 助理升级。升级后上线了图片理解、文档速读、工作流等产品能力,率先探索多模态、长文本与 RPA 技术在 AI 应用的落地。 基于阿里通义千问大模型,升级后的钉钉 AI 助理可以做到: …