作者:zhaobo | 来源:互联网 | 2023-10-12 16:55
热点参数限流
何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如:
- 商品 ID 为参数,统计一段时间内最常购买的商品 ID 并进行限制
- 用户 ID 为参数,针对一段时间内频繁访问的用户 ID 进行限制
热点参数限流会统计传入参数中的热点参数,并根据配置的限流阈值与模式,对包含热点参数的资源调用进行限流。热点参数限流可以看做是一种特殊的流量控制,仅对包含热点参数的资源调用生效。
根据上述的解释,我们知道热点参数限流的主要目的是根据请求资源进行更加细粒化的限流。
实例分析
热点参数分为两部分设计
- 热点规则
- 参数例外项
从名字中不难理解这些参数的意思。
对应的代码如下:
@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,o(╥﹏╥)o";
}
设置完成中,在进行测试的会发现,参数1 p1会被限流,参数2不会被限流,需要注意的是参数例外性只支持8大基本数据类型。