Sentinel --学习笔记

什么是Sentinel?

Sentinel是阿里巴巴开源的一款服务保护框架,旨在保障分布式系统的稳定性和高可用性。可以想象它就像是分布式系统中的交通警察,它的职责是监控系统流量和请求,确保在高峰时段或者遇到意外情况时,系统能够平稳运行,不会因为过载而崩溃。

Sentinel功能简述:

  1. 流量控制:限制处理请求的数量,防止系统因过载崩溃。
  2. 熔断降级:在服务异常时自动停止请求,提供备选响应。
  3. 系统负载保护:根据系统当前负载动态调整请求处理能力。
  4. 热点参数限流:对特定热点数据的访问进行细粒度的限流。
  5. 授权规则:根据请求者身份或来源进行请求的访问控制。
  6. 监控和管理:提供实时的服务监控与动态配置能力。

Sentinel的使用

Sentinel 的使用可以分为两个部分:

  • 核心库(Jar包):不依赖任何框架/库,能够运行于 Java 8 及以上的版本的运行时环境,同时对 Dubbo / Spring Cloud 等框架也有较好的支持。在项目中引入依赖即可实现服务限流、隔离、熔断等功能。

  • 控制台(Dashboard):Dashboard 主要负责管理推送规则、监控、管理机器信息等

Sentinel配置

1、下载jar包

Releases · alibaba/Sentinel (github.com)

2、运行jar包

首先进入到jar包所在目录,打开cmd,输入下面命令:

java -Dserver.port=8090 -Dcsp.sentinel.dashboard.server=localhost:8090 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar(jar包名)

3、访问

通过localhost:8090就可以访问sentinel的控制台了,初始用户名密码默认都是sentinel

项目配置

1、引入依赖

<!--sentinel-->
<dependency>
    <groupId>com.alibaba.cloud</groupId> 
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

2、修改配置文件

spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8090
      http-method-specify: true # 开启请求方式前缀

请求限流

此时再对配置好的项目进行访问,在sentinel的控制台-->簇点链路就可以看到相关访问记录了,在簇点链路后面点击流控按钮,即可对其做限流配置:

配置也很简单,如图所示,设置qps(每秒访问率)或者并发线程数的阈值即可,只要超过设置的阈值的访问就会被拒绝

服务熔断

Sentinel中的断路器不仅可以统计某个接口的慢请求比例 ,还可以统计异常请求比例 。当这些比例超出阈值时,就会熔断该接口,即拦截访问该接口的一切请求,降级处理;当该接口恢复正常时,再放行对于该接口的请求。

断路器的工作状态切换有一个状态机来控制:

状态机包括三个状态:

  • closed:关闭状态,断路器放行所有请求,并开始统计异常比例、慢请求比例。超过阈值则切换到open状态

  • open :打开状态,服务调用被熔断,访问被熔断服务的请求会被拒绝,快速失败,直接走降级逻辑。Open状态持续一段时间后会进入half-open状态

  • half-open:半开状态,放行一次请求,根据执行结果来判断接下来的操作。

    • 请求成功:则切换到closed状态

    • 请求失败:则切换到open状态

我们可以在控制台通过点击簇点后的**熔断**按钮来配置熔断策略:

这种是按照慢调用比例来做熔断,上述配置的含义是:

  • RT超过200毫秒的请求调用就是慢调用

  • 统计最近1000ms内的最少5次请求,如果慢调用比例不低于0.5,则触发熔断

  • 熔断持续时长20s

相关推荐
十年一梦实验室11 分钟前
【C++】相机标定源码笔记- RGB 相机与 ToF 深度传感器校准类
开发语言·c++·笔记·数码相机·计算机视觉
是Yu欸1 小时前
【前端实现】在父组件中调用公共子组件:注意事项&逻辑示例 + 将后端数组数据格式转换为前端对象数组形式 + 增加和删除行
前端·vue.js·笔记·ui·vue
youyoufenglai1 小时前
【HarmonyOS4学习笔记】《HarmonyOS4+NEXT星河版入门到企业级实战教程》课程学习笔记(二十)
笔记·学习·鸿蒙
杂鱼Tong1 小时前
13. Revit API: Filter(过滤器)
笔记
人不走空2 小时前
高考假期预习指南
学习·高考
码--到成功2 小时前
HTML CSS 基础复习笔记 - 列表使用
css·笔记·html
在线OJ的阿川2 小时前
大数据基础知识【大数据导论】
大数据·经验分享·学习
javaer炒粉3 小时前
鸿蒙应用笔记
笔记·华为·harmonyos
AI2中文网3 小时前
【最新】App Inventor 2 学习平台和AI2伴侣使用
学习·网址·平台·资源·app inventor 2·appinventor·ai伴侣
petaexpress3 小时前
K8S学习教程(二):在 PetaExpress KubeSphere容器平台部署高可用 Redis 集群
redis·学习·kubernetes