如何集成Sentinel实现流控、降级、热点规则、授权规则总结

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 如何集成Sentinel实现流控、降级、热点规则、授权规则总结

如何集成Sentinel实现流控、降级、热点规则、授权规则总结

Sentinel是一款开源的分布式系统流量防卫兵,通过流控、降级、热点规则、授权规则等功能,提供了对系统稳定性和性能的强大保障。下面我们将介绍如何在项目中集成Sentinel,并使用其强大的功能来保障系统的稳定性和可用性。

1. 添加依赖

首先,在项目的pom.xml文件中添加Sentinel的依赖:

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

2. 配置文件中指定Sentinel地址

在application.yml(或application.properties)中添加Sentinel的配置信息,指定控制台地址:

spring:
  cloud:
    sentinel:
      transport:
        dashboard: localhost:8080  # Sentinel控制台地址

3. 启动Sentinel控制台

启动Sentinel控制台,访问http://localhost:8080,即可进入控制台进行规则的配置和监控。

4. 流控规则

QPS和线程数流控

在控制台设置QPS和线程数的流控规则,当请求超过限定的QPS或服务器线程数超过指定值时,自动拒绝请求。

流控效果

  • 快速失败:直接拒绝请求。
  • 预热:前期QPS是设置的QPS的三分之一,随着时间的加载,慢慢到达设置QPS。
  • 排队:当设置QPS之后,后续请求默认进行排队,有限时间内排队。

关联流控和链路流控

关联流控用于处理资源竞争情况,当核心资源(资源1)达到阈值后,限流资源2。链路流控可在业务层指定某个链路进行控流。

5. 降级规则

降级规则在执行业务之后进行统计,根据不同情况触发熔断。

慢比例调用

指定多长时间的请求判定为慢请求,当慢请求比例到达设置的值时,自动熔断,熔断的时间由自行设置。

异常比例和异常数

当请求的错误比例或异常数量达到设置的阈值时,触发熔断。

6. 热点规则

通过利用公司的热点key,发现哪些参数的查询/处理属于热点数据,需要对热点数据进行限流。在Sentinel控制台中进行相关规则的配置,确保热点数据的处理不会影响系统整体性能。

7. 授权规则

授权规则涉及接口的权限管理,需要在系统中添加接口实现类,解析/获取请求中的权限信息。在Sentinel控制台中设置白名单和黑名单,对访问进行管控。

8. 自定义异常的返回

为了更好地处理Sentinel的异常情况,可以创建一个自定义异常处理类,实现BlockExceptionHandler接口。通过该类,可以对不同类型的异常进行定制化的处理。

@Component
public class ExceptionHandlerPage implements BlockExceptionHandler {
    // 实现异常处理逻辑
}

9. SentinealResource注解使用

通过@SentinelResource注解,可以在针对某一个地址做特殊响应的时候,进行定制化返回。这提供了更灵活的方式来处理特定场景下的流控和降级。

@SentinelResource(value = "example", blockHandler = "handleBlock", fallback = "handleFallback")
public String example() {
    // Your business logic here
}

10. Feign集成Sentinel

在使用Feign进行远程调用时,默认情况下是没有集成Sentinel的支持的。为了在远程服务不可用的情况下,保证请求不报错,可以进行如下配置。

在Feign的配置文件中,开启Sentinel的支持:

feign:
  sentinel:
    enabled: true

这样,当远程服务不可用时,Feign会走本地的方法,返回预设的兜底数据,确保请求不会因远程服务不可用而报错。

公司中怎么用Sentinel

  1. 压测:在公司中,使用Sentinel通常会先进行系统的整体压测,以确保系统在高并发和异常情况下的稳定性。这包括单个功能的压测以及整体应用的压测,模拟用户访问应用流量分布。
  • 单个功能压测: 针对系统中的某个功能进行压测,检查该功能在高负载情况下的性能表现。
  • 整体压测: 综合考虑整个应用的各个功能,得出整个应用中哪些请求比较耗时,模拟用户访问应用流量分布。
  1. 规则配置与优化: 根据压测结果,在Sentinel控制台中对系统进行有针对性的规则配置,包括流控、降级、热点规则等。通过监控系统运行情况,进一步优化规则配置,确保系统在高并发和异常情况下仍能稳定运行。
  2. 监控与调整: 使用Sentinel监控系统的实时运行情况,根据监控数据进行规则的动态调整,保证系统在不同业务场景下的稳定性。

如果大家觉得有用的话,可以关注我下面的微信公众号,极客李华,我会在里面更新更多行业资讯,企业面试内容,编程资源,如何写出可以让大厂面试官眼前一亮的简历,让大家更好学习编程,我的抖音,B站也叫极客李华。

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
7月前
|
监控 API 开发者
Sentinel之道:流控模式解析与深度探讨
Sentinel之道:流控模式解析与深度探讨
178 0
|
7月前
|
Java 数据库连接 Maven
如何使用Sentinel实现流控和降级
通过以上步骤,你可以使用Sentinel实现应用的流量控制和降级操作,以保护系统在高流量或不稳定情况下的稳定性。欢迎关注威哥爱编程,一起学习成长。
109 1
|
3月前
|
监控 Java API
谷粒商城笔记+踩坑(25)——整合Sentinel实现流控和熔断降级
先简单介绍熔断、降级等核心概念,然后阐述SpringBoot整合Sentinel的实现方式,最后介绍Sentinel在本项目中的应用。
谷粒商城笔记+踩坑(25)——整合Sentinel实现流控和熔断降级
|
4月前
|
jenkins 测试技术 持续交付
解锁.NET项目高效秘籍:从理论迷雾到实践巅峰,持续集成与自动化测试如何悄然改变游戏规则?
【8月更文挑战第28天】在软件开发领域,持续集成(CI)与自动化测试已成为提升效率和质量的关键工具。尤其在.NET项目中,二者的结合能显著提高开发速度并保证软件稳定性。本文将从理论到实践,详细介绍CI与自动化测试的重要性,并以ASP.NET Core Web API项目为例,演示如何使用Jenkins和NUnit实现自动化构建与测试。每次代码提交后,Jenkins自动触发构建流程,通过编译和运行NUnit测试确保代码质量。这种方式不仅节省了时间,还能快速发现并解决问题,推动.NET项目开发迈向更高水平。
51 8
|
4月前
|
Java Spring UED
Spring框架的异常处理秘籍:打造不败之身的应用!
【8月更文挑战第31天】在软件开发中,异常处理对应用的稳定性和健壮性至关重要。Spring框架提供了一套完善的异常处理机制,包括使用`@ExceptionHandler`注解和配置`@ControllerAdvice`。本文将详细介绍这两种方式,并通过示例代码展示其具体应用。`@ExceptionHandler`可用于控制器类中的方法,处理特定异常;而`@ControllerAdvice`则允许定义全局异常处理器,捕获多个控制器中的异常。
54 0
|
5月前
|
监控 算法 Java
高并发架构设计三大利器:缓存、限流和降级问题之配置Sentinel的流量控制规则问题如何解决
高并发架构设计三大利器:缓存、限流和降级问题之配置Sentinel的流量控制规则问题如何解决
|
6月前
|
监控 Java API
深入解析 Spring Cloud Sentinel:分布式系统流量控制与熔断降级的全面指南
深入解析 Spring Cloud Sentinel:分布式系统流量控制与熔断降级的全面指南
134 0
深入解析 Spring Cloud Sentinel:分布式系统流量控制与熔断降级的全面指南
|
6月前
|
自然语言处理 监控 开发者
springCloud之Sentinel流量路由、流量控制、流量整形、熔断降级
springCloud之Sentinel流量路由、流量控制、流量整形、熔断降级
127 0
|
7月前
|
监控 数据挖掘 索引
深度剖析Sentinel热点规则
深度剖析Sentinel热点规则
223 1
|
7月前
|
监控 Java API
解密Sentinel中流控规则的阀值奥秘
解密Sentinel中流控规则的阀值奥秘
63 0
解密Sentinel中流控规则的阀值奥秘