Sentinel热点规则分析

Sentinel热点参数限流用于限制高频访问的数据,如商品ID、用户ID等。通过LRU策略和令牌桶算法实现限流。限流模式仅支持QPS,参数索引对应方法参数位置。当超过单机阈值时触发限流,表现为ParamFlowException异常。热点参数限流提供更细粒度的控制,适用于流量波动大的资源,如特定商品。配置参数例外项可设定不同参数值的阈值。
摘要由CSDN通过智能技术生成

何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值