何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top N 数据,并对其访问进行限制。比如:
- 商品 ID 为参数,统计一段时间内最常购买的商品 ID 并进行限制。
- 用户 ID 为参数,针对一段时间内频繁访问的用户 ID 进行限制。
热点参数限流会统计传入参数中的热点数据,并根据配置的限流阈值与模式,对包含热点参数的资源调用进行限流。热点参数限流可以看做是一种特殊的流量控制,仅对包含热点参数的资源调用生效。其中,Sentinel会利用 LRU 策略统计最近最常访问的热点参数,结合令牌桶算法来进行参数级别的流控。
/**
* 定义一个基于指定id获取数据的方法,通过此方法演示热点数据的限流
*/
@GetMapping("/consumer/doFindById/{id}")
@SentinelResource("dofindById")//不设定这个注解,热点规则不生效
public String doFindById(@PathVariable Integer id) {
return "hot id is"+id;
}
浏览器输入:localhost:8090/consumer/doFindById/100
或者:
@GetMapping("/consumer/doFindById")
@SentinelResource("doFindById")
public Strin