Sentinel热点key限流
是什么
何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如:
- 商品 ID 为参数,统计一段时间内最常购买的商品 ID 并进行限制
- 用户 ID 为参数,针对一段时间内频繁访问的用户 ID 进行限制
热点参数限流会统计传入参数中的热点参数,并根据配置的限流阈值与模式,对包含热点参数的资源调用进行限流。
热点参数限流可以看做是一种特殊的流量控制,仅对包含热点参数的资源调用生效。
兜底的方法:
- 系统默认的方法
- 客户自定义的方法
之前的case,限流出问题后,都是用sentinel系统默认的提示:Blocked by Sentinel (flow limiting)
那么我们能不能自定?类似Hystrix,某个方法出问题了,就找对应的兜底降级方法?
从HystrixCommond到@SentinelResource
Sentinel热点参数限流
Controller层示例代码:
//热点限流
@GetMapping("/testHotKey")
@SentinelResource(value = "testHotKey", blockHandler = "deal_testHotKey")
public String testHotKey(@RequestParam(value = "p1", required = false) String p1,
@RequestParam(value = "p2", required = false) String p2) {
return "*****testHotKey";
}
public String deal_testHotKey (String p1, String p2, BlockException exception) {
return "****deal_testHotKey";
}
如果失败用deal_testHotKey这个方法来兜底。
配置:索引为第0个的参数(p1)阈值为1
限流模式仅支持QPS模式
方法testHotKey里面第一个参数只要QPS超过每秒1次,拿上降级处理。
携带p1参数快速多次访问:
超过1秒一次的限制,触发blockHandler方法。
携带p2参数快速访问多次:
一切正常。
同时携带p1和p2参数快速访问:
触发blockHandler方法。
参数例外项
上述案例在访问超过1秒1个后马上被限流。但是,我们希望p1参数当它时某个特殊值时,它的限流值和平时不一样。
比如:当p1=5时,它的阈值可以达到200;其它值仍然为1
举个例子,当一个数小于5的时候对他进行限制,如果大于5的时候不对他进行限制。就是这个意思。
配置如下:
说明:上面的不用解释,下面的参数例外项
其中的参数类型包含8种基本数据类型和String类型
当上面设置的0号参数的值达到5时,他的QPS值可以达到200。
测试如下:
- 携带p1=5快速多次访问:正常
- 携带p1=3快速多次访问:触发blockHandler方法
注意:
@SentinelResource处理的是Sentinel控制台配置的违规情况,有blockHandler方法配置的兜底处理;
如果逻辑代码中出现其它RuntimeException,@SentinelResource是不管的。