• 51.Sentinel微服务保护


    目录

    (1)初识Sentinel。

    (1.1)雪崩问题及解决方案。

    (1.1.1)雪崩问题。

    (1.1.2)解决雪崩问题的四种方式。

    (1.1.3)总结。

    (1.2)服务保护技术对比。

    (1.3)Sentinel介绍和安装。

    (1.4)微服务整合Sentinel。

    (2)流量控制。

    (2.1)简单流控。

    (2.2)流控模式(直接、关联、链路)。

    (2.3)流控效果(快速失败、warm up、排队等待)。

    (2.4)热点参数限流。 

    (3)线程隔离、熔断降级。

    ​编辑 (3.1)FeignClient整合Sentinel。

    (3.2)线程隔离(舱壁模式)(线程池隔离、信号量隔离)。

    (3.3)熔断降级(慢调用、异常比例、异常数)。

    ​编辑

    (4)授权规则。

    (4.1) 授权规则。

    (4.2)自定义异常结果。

    (4.3)总结。

    (5) 系统规则。

    (6)规则持久化。

    (6.1)规则管理模式。

    (6.2)实现push模式。

    (7)浏览器清除缓存的技巧。


    (1)初识Sentinel。

    (1.1)雪崩问题及解决方案。

    (1.1.1)雪崩问题。

    雪崩:一个微服务A依赖(即发送请求,等回应)于另一个微服务B,如果B出现故障,没有回应,则A的这条访问就不会结束(请求不释放),等到微服务A的请求资源都用完后,A也废了(所有访问资源都被占用了)。然后一些微服务依赖服务A的,也得不到A的回应,也跟着废了。这就是雪崩,因为一个微服务出现故障,导致凡是依赖于它的微服务也出现故障。

    (1.1.2)解决雪崩问题的四种方式。

    提示:前三种是处理出现故障的微服务避免故障传递从而导致雪崩,第四种是预防雪崩,就是还没发生故障的。

    (1.1.3)总结。

    (1.2)服务保护技术对比。

    (1.3)Sentinel介绍和安装。

    开启的效果如下(部分截图): 


    (1.4)微服务整合Sentinel。

    提示:整合好之后,启动项目后,需要访问过服务器之后,在sentinel里面才能看到显示 。

    1. <dependency>
    2. <groupId>com.alibaba.cloudgroupId>
    3. <artifactId>spring-cloud-starter-alibaba-sentinelartifactId>
    4. <version>2.2.1.RELEASEversion>
    5. dependency>


    (2)流量控制。

    (2.1)简单流控。

    每一个端点(Endpoint):可以理解成controller中的每个方法。

    QPS 是 "Queries Per Second"(每秒查询数)的缩写:即每秒的请求量。

    并发量:表示系统在同一时刻需要处理的请求总数。

    提示:被请求过的方法才会被监控到,想要监控它,先请求它。


    请求效果如下:每秒访问10次,5次成功,5次失败。 

    (2.2)流控模式(直接、关联、链路)。

    链路:就是对请求来源进行限流。(例如:有ABC三个资源,A和B都要访问C,在统计资源C的时候,只统计某个入口资源,如A或B,如果超过阈值,则限流C)

    特别说明:

     如果不关闭这个,则所有controller中的方法访问service服务层的该监控方法时,都认为是同一个来源,所以就起不到链路的作用。(需要要配这个参数,不然链路模式不起作用)


    以下是关联模式达到阈值后的限流:

    (2.3)流控效果(快速失败、warm up、排队等待)。

    warm up也叫预热模式:作用就是给刚启动的服务器一些缓冲的时间,让服务器刚开始时处理的请求少一些,然后慢慢增加到正常数量。(初始化QPS是3,然后慢慢增加,达到预热时间后,QPS就变成设置值的QPS了)

    排队等待:如果设置的超时时间是5秒,而每秒只能处理10个,那么队列只能放50个。(例如,空闲服务器突然1秒内有60个请求,处理10个,50个放进队列,都能处理完。若是1秒内61,那么有一个不能进入队列,直接返回异常。) (计算失败的请求数量:就是当多出来的超过队列最大容量时,则后面每秒只能进入每秒处理的请求个数,多出来的都会返回异常,例如:超时是5秒,每秒出来1个请求,我每秒请求2次,则第五秒正好队列排满,之后每秒只能进队列1个(每秒处理的个数),多出来的1个请求只能返回异常)。

    (2.4)热点参数限流。 

    热点参数限流对默认的SpringMVC资源无效:解决方法就是给springmvc的方法加上@SentinelResource("hot")注解,里面的hot是给这个资源起的名称。



    (3)线程隔离、熔断降级。

    线程隔离:就是给每个业务分配一定数量的线程, 即便某业务调用的服务器垮了,也能处理其他业务。

    熔断降级:就是按访问的成功与失败的比例,如果失败比例过大,则禁止访问该业务。


     (3.1)FeignClient整合Sentinel。

    我这里出现一个异常:

    Caused by: java.lang.IllegalStateException: Incompatible fallbackFactory instance. Fallback/fallbackFactory of type class cn.itcast.feign.clients.fallback.UserClientFallbackFactory is not assignable to interface org.springframework.cloud.openfeign.FallbackFactory for feign client userservice

     解决办法:因为是版本不兼容,换个版本就行。

    1. <dependency>
    2. <groupId>com.alibaba.cloudgroupId>
    3. <artifactId>spring-cloud-starter-alibaba-sentinelartifactId>
    4. <version>2.2.1.RELEASEversion>
    5. dependency>

    本来成功运行了,但是今天早上重新开启服务的时候有报错了:

    解决方法是:把Hoxton.SR10换成Hoxton.SR8就可以成功启动服务器了

    1. <spring-cloud.version>Hoxton.SR8spring-cloud.version>

    (3.2)线程隔离(舱壁模式)(线程池隔离、信号量隔离)。

    (3.3)熔断降级(慢调用、异常比例、异常数)。

    (4)授权规则。

    (4.1) 授权规则。

    授权规则:可以做身份验证,网关也可以身份验证,但是万一泄露了微服务的地址,那么别人可以绕过网关,直接访问微服务,该授权规则就是拦截不是从网关过来的请求。

    解析:下方的流控应用填写的名称是实现的RequestOriginParser接口的parseOrigin方法的返回值(当然也可以写其他,可操作空间挺大的),当返回值与流控应用的值一样时,则允许访问,否则拒绝访问。


    (4.2)自定义异常结果。

    FallbackFactory接口和BlockExceptionHandler接口是的区别:

    1. FallbackFactory接口:FallbackFactory接口通常用于实现服务降级的逻辑。当原始服务不可用时,fallback对象会代替原始服务进行处理,并返回预先定义的默认响应或错误信息。(用于远程调用feign,当feign出现异常或熔断隔离,就会调用这个接口的实现

    2. BlockExceptionHandler接口:BlockExceptionHandler接口通常用于处理限流和熔断的异常情况。BlockExceptionHandler接口允许自定义异常处理逻辑,在请求被限流或触发熔断时,可以定义如何处理这些异常情况。(只要不是远程调用,请求被sentinel限流授权等操作,就会调用该实现


    (4.3)总结。

    (5) 系统规则。

    只对linux系统有用,对sentinel应用的主机进行保护措施。 

    (6)规则持久化。

    (6.1)规则管理模式。

    (6.2)实现push模式。

    注意:如果没变化的话,要清除缓存。

    方法:开发者模式下,右键点击浏览器刷新按钮(位于地址栏旁边),选择"清除缓存并强制重新加载"选项。 

    1. # 这里除了配置了flow还配了degrade,如果还要配其他的,就按照这个格式(把xxx换成需要配置的类型,有三个xxx)
    2. spring:
    3. cloud:
    4. sentinel:
    5. datasource:
    6. flow:
    7. nacos:
    8. server-addr: localhost:8848 # nacos地址
    9. dataId: orderservice-flow-rules
    10. groupId: SENTINEL_GROUP
    11. rule-type: flow # 还可以是:degrade、authority、param-flow
    12. degrade:
    13. nacos:
    14. server-addr: localhost:8848 # nacos地址
    15. dataId: orderservice-degrade-rules
    16. groupId: SENTINEL_GROUP
    17. rule-type: degrade # 还可以是:degrade、authority、param-flow
    18. xxx:
    19. nacos:
    20. server-addr: localhost:8848 # nacos地址
    21. dataId: orderservice-xxx-rules
    22. groupId: SENTINEL_GROUP
    23. rule-type: xxx # 还可以是:degrade、authority、param-flow

    sentinel的效果如下:只配置了持久化的流控规则。

     添加持久化的流控规则后,去nacos控制台看配置列表:多出了一个配置文件。

    (7)浏览器清除缓存的技巧。

    总结:开发者模式下,右键点击浏览器刷新按钮(位于地址栏旁边),选择"清除缓存并强制重新加载"选项。

    Google Chrome浏览器:

    1. 在Chrome浏览器中,按下快捷键"Ctrl + Shift + I"(Windows)或"Cmd + Option + I"(Mac)打开开发者工具。
    2. 在开发者工具中,右键点击浏览器刷新按钮(位于地址栏旁边),选择"清除缓存并强制重新加载"选项。
    3. 或者,按下快捷键"Ctrl + F5"或"Shift + F5",这会强制刷新页面并清除缓存。

    Mozilla Firefox浏览器:

    1. 在Firefox浏览器中,按下快捷键"Ctrl + Shift + I"(Windows)或"Cmd + Option + I"(Mac)打开开发者工具。
    2. 在开发者工具中,右键点击浏览器刷新按钮(位于地址栏旁边),选择"清除缓存和硬重载"选项。
    3. 或者,按下快捷键"Ctrl + F5"或"Shift + F5",这会强制刷新页面并清除缓存。

    Microsoft Edge浏览器:

    1. 在Edge浏览器中,按下快捷键"Ctrl + Shift + I"(Windows)或"Cmd + Option + I"(Mac)打开开发者工具。
    2. 在开发者工具中,右键点击浏览器刷新按钮(位于地址栏旁边),选择"清除浏览器缓存"选项。
    3. 或者,按下快捷键"Ctrl + F5"或"Shift + F5",这会强制刷新页面并清除缓存。

  • 相关阅读:
    奇异值分解(SVD)原理与在降维中的应用(附带例题讲解)(纯理论)
    C++设计模式之Strategy策略模式
    【开源】JAVA+Vue.js实现高校学生管理系统
    YOLOv6在LabVIEW中的推理部署(含源码)
    Crony 一个基于Go语言实现的分布式定时任务管理平台
    测试用例、测试套件、测试加载器的用法
    【经典算法学习-排序篇】顺序查找 - 作业讲解
    # 算法与程序的灵魂
    [Linux]下制作简易myshell
    echarts 图片导入到 word pdf
  • 原文地址:https://blog.csdn.net/khmff/article/details/134428628