微服务保护Sentinel一站式学习

微服务保护Sentinel

雪崩问题

在这里插入图片描述

解决雪崩问题的四种常见方式:

  • 超时处理:设定超时时间,请求超过一定时间没有响应就返回错误信息,不会无休止等待。如果设置一秒钟没响应返回,即1s释放连接,这1s中有好多个请求进来,来不及释放也会造成资源堵塞
  • 舱壁模式:限定每个业务能使用的线程数,避免耗尽整个tomcat的资源,也叫线程隔离。还是有问题,如果服务挂了,下游服务还是会不停的请求,虽然有线程数控制,但是还是会有请求进来,即使明知道服务挂了,会造成分配给这个服务的资源浪费
  • 熔断降级:由断路器统计业务执行的异常比例,如果超出阈值则会熔断该业务,拦截访问业务的一切请求。没啥问题,现在主流都是用这个
  • 流量控制:限制业务访问的QPS,预防服务因流量的突增而故障。

服务技术对比

在这里插入图片描述


搭建sentinel

  1. 引入依赖,下游服务引,比如orderservice调用userservice方法,在orderservice中引入
<!--        引入sentinel依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>
  1. 配置yaml
spring:  
  cloud:
    sentinel:
      transport:
        dashboard: 127.0.0.1:8080

流控规则


簇点链路

簇点链路:就是项目内的调用链路,链路中被监控的每个接口就是一个资源。

默认情况下sentinel会监控SpringMVC的每一个端点 (Endpoint),因此SpringMVC的每一个端点 (Endpoint)就是调用链路中的一个资源。

流控、熔断等都是针对簇点链路中的资源来设置的,因此我们可以点击对应资源后面的按钮来设置规则:流控 / 降级 / 热点 / 授权

在这里插入图片描述

  • 单机阈值:QPS不能超过5,每秒钟只允许5次请求,超出的请求会被拦截并报错

高级选项

在添加限流规则时,点击高级选项,可以选择三种流控模式:

  • 直接:统计当前资源的请求,触发闻值时对当前资源直接限流,也是默认的模式
  • 关联:统计与当前资源相关的另一个资源,触发闻值时,对当前资源限流
  • 链路:统计从指定链路访问到本资源的请求,触发闯值时,对指定链路限流

流控模式


流控模式-限流

关联模式:统计与当前资源相关的另一个资源,触发闻值时,对当前资源限流

使用场景:比如用户支付时需要修改订单状态,同时用户要查询订单。查询和修改操作会争抢数据库锁,产生竞争业务需求是有限支付和更新订单的业务,因此当修改订单业务触发闻值时,需要对查询订单业务限流

限制/order/query资源,

在这里插入图片描述

总结:

满足下面条件可以使用关联模式:

  • 两个有竞争关系的资源
  • 一个优先级较高,一个优先级较低

流控模式-链路

链路模式:只针对从指定链路访问到本资源的请求做统计,判断是否超过阈值

假设现在有两条链路:

  • /order/save–>/query
  • /order/query–>/query

对query资源做链路限制,限制/order/query这个资源入口的qps

在这里插入图片描述

spring:    
    cloud:
      sentinel:
        transport:
          dashboard: 127.0.0.1:8080
        web-context-unify: false # sentinel默认会将controller方法做context整合,导致链路模式的流控失败,现在要把service里的方法也要监控到
        #链路模式中,是对不同来源的两个链路做监控,但是sentinel默认会给进入springmvc的所有请求设置同一个root资源,会导致链路失败
@SentinelResource("query")//将该资源交给sentinel监控
public String query() {
    return "查询成功";
}

流控效果


流控效果-warm up

warm up也叫预热模式,是应对服务冷启动的一种方案。请求闻值初始值是threshold/coldFactor,持续指定时长后,逐渐提高到threshold值。而coldFactor的默认值是3.
例如,我设置QPS的threshold为10,预热时间为5秒,那么初始闻值就是 10/3,也就是3,然后在5秒后逐渐增长到10.

在这里插入图片描述

流控效果-排队等待

当请求超过QPS闻值时,快速失败和warm up 会拒绝新的请求并抛出异常。而排队等待则是让所有请求进入一个队列中然后按照闻值允许的时间间隔依次执行。后来的请求必须等待前面执行完成,如果请求预期的等待时间超出最大时长则会被拒绝。

在这里插入图片描述

虽然不能确定进来的流量是怎么样的,但是可以保证出去的流量是200ms一个出去,起到流量整形的作用


热点参数限流

热点参数限流分别统计参数值相同的请求,是否超过QPS阈值

下面这个代表对hot这个资源的0号参数做统计,每秒的QPS不饿能超过2,但是102/103是可以超过2的,只是不能超过10/4

在这里插入图片描述

需要注意的是:热点参数限流对默认的Springmvc资源无效,需要加之前用过的注解@SentinelResouce

@SentinelResource("hot")
@GetMapping("{orderId}")
public Order queryOrderByUserId(@PathVariable("orderId") Long orderId) {
    // 根据id查询订单并返回
    return orderService.queryOrderById(orderId);
}

隔离和降级

虽然限流可以尽量避免因高并发而引起的服务故障,但服务还会因为其它原因而故障。而要将这些故障控制在一定范围避免雪崩,就要靠线程隔离(舱壁模式)和熔断降级手段了。

不管隔离还是熔断,都是对客户端(调用者)的保护(下游服务)。

Feign整合Sentinel

  1. 引入依赖
<!--        引入sentinel依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>
  1. 配置yaml
spring:    
    sentinel:
      enabled: true #开启feign对sentinel的支持
  1. 在feign中:

    • 第一步:在feign-api项目中的UserClientFallbackFactory编写降级规则,需要继承FallbackFactory

      • @Slf4j
        public class UserClientFallbackFactory implements FallbackFactory<UserClient> {
        
            @Override
            public UserClient create(Throwable throwable) {
                return new UserClient() {
                    @Override
                    public User findById(Long id) {
                        log.error("查询用户异常" + throwable);
                        return new User();
                    }
                };
            }
        }
        
    • 第二步:将这个UserClientFallbackFactory注册成bean

      • public class FeignClientConfiguration {
            @Bean
            public Logger.Level feignLogLevel(){
                return Logger.Level.BASIC;
            }
            @Bean
            public UserClientFallbackFactory userClientFallbackFactory(){
                return new UserClientFallbackFactory();
            }
        }
        
    • 第三步:在调用接口的头上补充注解

      • @FeignClient(value = "userservice",fallbackFactory = UserClientFallbackFactory.class)
        public interface UserClient {
        
            @GetMapping("/user/{id}")
            User findById(@PathVariable("id")Long id);
        }
        

线程隔离

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


熔断降级

熔断降级是解决雪崩问题的重要手段。其思路是由断路器统计服务调用的异常比例、慢请求比例,如果超出闻值则会熔断该服务。即拦截访问该服务的一切请求,而当服务恢复时,断路器会放行访问该服务的请求。


断路器的状态

在这里插入图片描述

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

  • 慢调用:业务的响应时长(RT)大于指定时长的请求认定为慢调用请求。在指定时间内,如果请求数量超过设定的最小数量,慢调用比例大于设定的闯值,则触发熔断。
  • 异常比例或异常数:统计指定时间内的调用,如果调用次数超过指定请求数,并且出现异常的比例达到设定的比例闻值(或超过指定异常数),则触发熔断。

慢调用

在这里插入图片描述

对这个/user/id资源进行降级,规定RT响应时间超过50ms的调用是慢调用,在1000ms中,如果请求>5,且慢调用比例大于0.4,则会触发熔断,熔断时间是1s。然后进入half-open状态,放行一次请求做测试。


异常比例

在这里插入图片描述

对这个/user/id资源进行降级,在1000ms中,如果请求数>5,且失败比例达到0.4,则触发熔断,熔断时间是1s。然后进入half-open状态,放行一次请求做测试。


授权规则

授权规则是对请求来源的判断,比如网关,浏览器,有些请求是浏览器通过网关转发到具体服务的,有些是越过网关直接到服务的。

在这里插入图片描述

gateway:
  default-filters:
    - AddRequestHeader=origin,gateway

在网关中配置:添加请求头信息:origin=gateway

在具体服务中实现接口,判断该请求有没有携带origin

@Component
public class HeaderOriginParser implements RequestOriginParser {

    @Override
    public String parseOrigin(HttpServletRequest httpServletRequest) {
        String origin = httpServletRequest.getHeader("origin");
        if (StringUtils.isEmpty(origin)){
            origin="blank";
        }
        return origin;
    }
}

自定义异常

默认情况下,发生限流、降级、授权拦截时,都会抛出异常到调用方。如果要自定义异常时的返回结果,需要实现BlockExceptionHandler接口。

在这里插入图片描述

@Component
public class MyBlockException implements BlockExceptionHandler {
    /**
     * 处理请求被限流,降级,授权拦截时抛出的异常:BlockException
     * @param httpServletRequest
     * @param httpServletResponse
     * @param e
     * @throws Exception
     */
    @Override
    public void handle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, BlockException e) throws Exception {
        String msg = "未知错误";
        int status = 429;
        if (e instanceof FlowException){
            msg = "请求被限流了";
        }else if (e instanceof DegradeException){
            msg="请求被降级了";
        } else if (e instanceof ParamFlowException) {
            msg="热点参数限流";
        } else if (e instanceof AuthorityException) {
            msg="请求没有权限";
            status = 401;
        }
        httpServletResponse.setStatus(status);
        httpServletResponse.setContentType("application/json;charset=utf-8");
        httpServletResponse.getWriter().println("message:"+ msg + ",status:"+ status);
    }
}

获取请求来源的接口是什么?

  • RequestOriginParser

处理BlockException的接口是什么?

  • BlockExceptionHandler

规则持久化

sentinel的控制台规则管理有三种:

  • 原始模式:sentinel的默认模式,将规则保存在内存中,重启服务会丢失
  • pull模式:保存在本地文件或数据库,定时读取
  • push模式:保存在nacos,监听变更实时更新

pull模式

在这里插入图片描述


push模式(推荐)

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

BOSS直拒、失联招聘,消失的“金三银四”,失业的测试人出路在哪里?

裁员潮涌&#xff0c;经济严冬。最近很多测试人过得并不好&#xff0c;行业缩水对测试岗位影响很直接干脆&#xff0c;究其原因还是测试门槛在IT行业较低&#xff0c;同质化测试人员比较多。但实际上成为一位好测试却有着较高的门槛&#xff0c;一名优秀的测试应当对产品的深层…

Stable Diffusion 视频和图片帧互换以及AI动画帧生成

Stable Diffusion 只做AI动画是基于把原有视频按照帧进行提取之后对每一帧的图像进行标准化流程操作&#xff0c;中间可以掺杂Controlnet对人物进行控制&#xff0c;使用关键词对画面进行控制&#xff0c;但是很多小伙伴不太会掌握一些编辑视频软件或者python的操作导致视频转帧…

Java 深入理解Servlet

动态资源与静态资源区别 servlet三及相关接口简介servet 执行过程servlet路径映射servlet生命周期(重点) --理解&#xff08;重点&#xff09;Servlet自动加载Servlet线程安全Servlet相关接口详解ServletContext对象 --知识点 一、Web项目结构 |- WebRoot : web应用的根目录…

【linux】常用命令大全(入门必备)

这篇文章涵盖了linux中常用的所有指令&#xff0c;欢迎大家阅读查询。(如有不正确的地方&#xff0c;各位大佬可以在评论区指出&#xff0c;我会及时进行更正)。 文章目录登录远程服务器ssh添加删除用户当前路径pwd列出文件目录ls进入cdtreewhoami创建文件touch创建目录mkdir删…

【C语言学习】循环结构和选择结构

C语言中有三大结构&#xff0c;分别是顺序结构、选择结构和循环结构&#xff08;分支结构&#xff09;&#xff1a; C语言顺序结构就是让程序按照从头到尾的顺序依次执行每一条C语言代码&#xff0c;不重复执行任何代码&#xff0c;也不跳过任何代码。 C语言选择结构也称分支结…

都说IT行业饱和了,2023年成为程序员还有发展前景吗?

程序员饱和了吗&#xff1f;初级码农肯定是算饱和了&#xff0c;因为大部分的互联网企业开始提高招聘要求了&#xff0c;比如技能要求、两三年工作经验、项目经验、软实力等&#xff0c;是按照中级开发人员的标准来的。所以干程序员还是有发展前景的&#xff0c;你的技能达标了…

Linux常用命令——locate命令

在线Linux命令查询工具 locate 比 find 好用的文件查找工具 补充说明 locate 让使用者可以很快速的搜寻档案系统内是否有指定的档案。其方法是先建立一个包括系统内所有档案名称及路径的数据库&#xff0c;之后当寻找时就只需查询这个数据库&#xff0c;而不必实际深入档案…

虹科喜报 | 虹科技术工程师【国内首批】拿下Redis认证开发者证书!

要说虹科数据库技术工程师有多强悍&#xff0c;认证考试2022年12月上线&#xff0c;次年2月就以全国首批速度强势通过考试&#xff0c;并于两周后正式收到【Redis认证开发人员】证书&#xff01; 虹科小云忍不住浅浅炫耀一下&#xff1a; 或许大家对Redis企业版数据库认证开发…

前端面试题之html css篇

文章目录1.什么是盒模型2.行内元素有哪些&#xff1f;块级元素有哪些&#xff1f; 空(void)元素有那些&#xff1f;行内元素和块级元素有什么区别&#xff1f;3.简述src和href的区别4.什么是css Hack5.什么叫优雅降级和渐进增强6.px和em的区别7.HTML5 为什么只写< !DOCTYPE …

[linux虚拟机]网络连接的三种模式和重要文件夹

桥接模式: 虚拟系统可以和外部系统通讯,但容易造成IP冲突NAT模式,网络地址转换模式,虚拟系统可以和外部系统通讯,不造成IP冲突主机模式:独立的系统 /bin [常用] (/usr/bin 、 /usr/local/bin) 是 Binary 的缩写, 这个目录存放着最经常使用的命令/sbin (/usr/sbin 、 /usr/loca…

2023年非业绩亏损ST股票投资策略研究报告

第一章 ST 股票概况 ST 股票是指中国股市上的一种特殊类型的股票&#xff0c;全称为“特别处理股票”&#xff0c;简称为 ST 股票。1998年4月22日&#xff0c;沪深证券交易所宣布将对财务状况和其他财务状况异常的上市公司的股票交易进行特别处理&#xff0c;由于“特别处理”…

VirtualBox安装centos宿主机与虚拟机网络互通、多个虚拟机之间网络互通、虚拟机可上外网

一&#xff0c;虚拟机的网络配置连接方式 选择 桥接网卡&#xff0c;界面名称 选择 当前宿主机能上网的网卡我现在电脑当前能上网的 网络名称是Remote NDIS .... &#xff0c;所以上面的界面名称选它&#xff1a;修改之后&#xff0c;重启centos虚拟机二&#xff0c;配置虚拟机…

代码随想录算法训练营第五十六天|583.两个字符串的删除操作、72.编辑距离

day56 2023/03/28 一、两个字符串的删除操作 给定两个单词 word1 和 word2&#xff0c;找到使得 word1 和 word2 相同所需的最小步数&#xff0c;每步可以删除任意一个字符串中的一个字符。 示例&#xff1a; 输入: "sea", "eat"输出: 2解释: 第一步将…

企业数字化中,BI 有何价值

在近些年的时间里&#xff0c;相关的数字化技术、理念、应用扩散到各行各业&#xff0c;让整个社会开始进行深层次的改变&#xff0c;也让城市建设这种传统的基础建设开始融合数字化&#xff0c;并利用数据结合数据中心、城市大脑等构建新型基础建设模式。 数据在这些年的时间…

AD83584D数字音频放大器

AD83584D是一款数字音频放大器&#xff0c;能够将25W&#xff08;BTL&#xff09;的功率分别驱动到一对8Ω负载扬声器&#xff0c;并将50W&#xff08;PBTL&#xff09;的功率驱动到一个4Ω负载扬声器。在24V电源下工作&#xff0c;无需外部散热器或风扇即可播放音乐。AD83584D…

第16章_多版本并发控制

第16章_多版本并发控制 &#x1f3e0;个人主页&#xff1a;shark-Gao &#x1f9d1;个人简介&#xff1a;大家好&#xff0c;我是shark-Gao&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f389;目前状况&#xff1a;23届毕业生&#xff0c;目…

数据库I (SELECT语句)

目录 一、写在前面 1.0 内容概览 1.1 SQL 分类 1.2 SQL语言的规则与规范 1.2.1 基本规则 1.2.2 SQL大小写规范 &#xff08;建议遵守&#xff09; 1.3 注释 1.4 命名规则&#xff08;暂时了解&#xff09; 二、基本的SELECT语句 2.0 SELECT... 2.1 SELECT ... FROM…

HTML5 Web Workers

HTML5 Web Workers web worker 是运行在后台的 JavaScript&#xff0c;不会影响页面的性能&#xff0c;更好的解释是&#xff0c;你可以使用web worker提供的一种简单的方法来为web内容在后台线程中运行脚本&#xff0c;这些线程在执行任务的过程中并不会干扰用户界面&#xff…

Java反射复习

Java反射复习1.动态代理2.创建动态代理3.反射4.获取Class对象5. 反射获取构造方法6. 获取成员变量7. 获取成员变量并获取值和修改值8.获取成员方法9. 获取成员方法并运行10. 面试题&#xff1a;11. 练习泛型擦除12 练习&#xff1a;修改字符串的内容13 练习&#xff0c;反射和配…

【新2023Q2模拟题JAVA】华为OD机试 - 寻找密码

最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为od机试,独家整理 已参加机试人员的实战技巧本篇题解:寻找密码 题目 小王在进行游…