SpringCloud Alibaba——Sentinel服务熔断与限流(三、热点规则)

简介: SpringCloud Alibaba——Sentinel服务熔断与限流(三、热点规则)

1.开篇



何为热点:热点即经常访问的数据,很多时候我们希望统计或者限制某个热点数据中访问频次最高的TopN数据,并对其访问进行限流或者其它操作。


兜底方法,分为系统默认和客户自定义两种:之前的case,限流出问题后,都是用sentinel系统默认的提示:Blocked by Sentinel (flow limiting)


我们能不能自定义类似hystrix,某个方法出问题了,就找对应的兜底降级方法?结论:从@HystrixCommand @SentinelResource

2.项目源码


github源码地址:https://github.com/2656307671/SpringCloud-Alibaba-Sentinel

gitee源码地址:https://gitee.com/szh-forever-young/SpringCloud-Alibaba-Sentinel

本次做Sentinel测试的代码请参考上面的仓库。对应的是controller中的 testHotKey 请求方法。

首先新增热点规则:👇👇👇


限流模式只支持QPS模式,固定写死了。(这才叫热点)


@SentinelResource注解的方法参数索引,0代表第一个参数p11代表第二个参数p2,以此类推。

单机阀值以及统计窗口时长表示在此窗口时间超过阀值就限流。上面的抓图就是第一个参数有值的话,1秒的QPS1,超过就限流,限流后调用deal_testHotKey降级方法。


下面我们到浏览器中访问 localhost:8401/testHotKey,后面要加上参数p11秒访问1次是不会出问题的,但是1秒内多次刷新访问,就会出现如下图结果,页面信息为testHotKey方法的降级方法中的内容。


由于在testHotKey方法中,参数p1p2都不是必须的。


如果请求url为:localhost:8401/testHotKey?p1=a,则1秒内多次访问会触发降级。

如果请求url为:localhost:8401/testHotKey?p2=b,则1秒内多次访问不会触发降级,因为我们定义的热点规则参数索引是0,是针对p1的。

如果请求url为:localhost:8401/testHotKey?p1=a&p2=b,则1秒内多次访问会触发降级。只要参数包含p1都符合热点规则。


下面再来说一下参数例外项。


普通情况:当访问url中包含p1的请求超过1秒钟1个之后,达到阈值1后马上被限流。

特例情况:我们期望p1参数当它是某个特殊值时,它的限流值和平时不样。假如当p1的值等于5时,它的阈值可以达到200


则需要在热点规则中进行如下配置:👇👇👇


上图的意思是说,热点规则面对的参数仍然是索引0p1),如果说p1的值为5,则满足参数例外项,此时阈值达到200,也就是说此时1秒内访问达到200次才会触发降级。所以下面在浏览器中访问,就可以得到testHotKey方法的返回值了。

如果说p1的值不是5,那么它的阈值仍然是上面的1,只要1秒内超过1次的访问,则直接触发降级。

相关文章
|
11月前
|
存储 数据可视化 Java
基于MicrometerTracing门面和Zipkin实现集成springcloud2023的服务追踪
Sleuth将会停止维护,Sleuth最新版本也只支持springboot2。作为替代可以使用MicrometerTracing在微服务中作为服务追踪的工具。
504 2
|
10月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
315 3
|
消息中间件 存储 Java
SpringCloud基础9——服务异步通信-高级篇
消息可靠性、死信交换机、惰性队列、MQ集群
SpringCloud基础9——服务异步通信-高级篇
|
XML 监控 Java
Spring Cloud全解析:熔断之Hystrix简介
Hystrix 是由 Netflix 开源的延迟和容错库,用于提高分布式系统的弹性。它通过断路器模式、资源隔离、服务降级及限流等机制防止服务雪崩。Hystrix 基于命令模式,通过 `HystrixCommand` 封装对外部依赖的调用逻辑。断路器能在依赖服务故障时快速返回备选响应,避免长时间等待。此外,Hystrix 还提供了监控功能,能够实时监控运行指标和配置变化。依赖管理方面,可通过 `@EnableHystrix` 启用 Hystrix 支持,并配置全局或局部的降级策略。结合 Feign 可实现客户端的服务降级。
684 23
|
负载均衡 监控 Java
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控
23634 7
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控
|
Java API 对象存储
微服务魔法启动!Spring Cloud与Netflix OSS联手,零基础也能创造服务奇迹!
这段内容介绍了如何使用Spring Cloud和Netflix OSS构建微服务架构。首先,基于Spring Boot创建项目并添加Spring Cloud依赖项。接着配置Eureka服务器实现服务发现,然后创建REST控制器作为API入口。为提高服务稳定性,利用Hystrix实现断路器模式。最后,在启动类中启用Eureka客户端功能。此外,还可集成其他Netflix OSS组件以增强系统功能。通过这些步骤,开发者可以更高效地构建稳定且可扩展的微服务系统。
177 1
|
运维 Java Nacos
Spring Cloud应用框架:Nacos作为服务注册中心和配置中心
Spring Cloud应用框架:Nacos作为服务注册中心和配置中心
|
Java Spring
spring cloud gateway在使用 zookeeper 注册中心时,配置https 进行服务转发
spring cloud gateway在使用 zookeeper 注册中心时,配置https 进行服务转发
344 3
|
存储 Java Spring
【Azure Spring Cloud】Azure Spring Cloud服务,如何获取应用程序日志文件呢?
【Azure Spring Cloud】Azure Spring Cloud服务,如何获取应用程序日志文件呢?
128 0
|
Java Spring
【Azure 服务总线】Spring Cloud 的应用 使用Service Bus 引起 org.springframework.beans.BeanInstantiationException 异常,无法启动
【Azure 服务总线】Spring Cloud 的应用 使用Service Bus 引起 org.springframework.beans.BeanInstantiationException 异常,无法启动
120 0