返回顶部
首页 > 资讯 > 后端开发 > Python >Sentinel热门词汇限流的实现详解
  • 320
分享到

Sentinel热门词汇限流的实现详解

2024-04-02 19:04:59 320人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录热点参数限流基本使用热点参数限流 何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如: 商品 ID 为参

热点参数限流

何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如:

  • 商品 ID 为参数,统计一段时间内最常购买的商品 ID 并进行限制
  • 用户 ID 为参数,针对一段时间内频繁访问的用户 ID 进行限制

热点参数限流会统计传入参数中的热点参数,并根据配置的限流阈值与模式,对包含热点参数的资源调用进行限流。热点参数限流可以看做是一种特殊的流量控制,仅对包含热点参数的资源调用生效。

基本使用

1、引入Maven依赖

<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-parameter-flow-control</artifactId>
    <version>x.y.z</version>
</dependency>

2、手动编写代码添加限流规则

@RequestMapping("/getUserOrder")
public String getUserOrder(Long userId) {
    Entry entry = null;
    try {
        entry = SphU.entry(getUserOrder, EntryType.IN, 1, userId);
        return "根据userId获取用户订单信息成功";
    } catch (Exception e) {
        return "您操作的比较频繁,请稍后重试!";
    } finally {
        if (entry != null) {
            entry.exit();
        }
    }
}
// 定义热点限流的规则,对第一个参数设置 qps 限流模式,阈值为1
ParamFlowRule rule = new ParamFlowRule(getUserOrder)
        .setParamIdx(0)
        .setGrade(RuleConstant.FLOW_GRADE_QPS)
        .setCount(1);
ParamFlowRuleManager.loadRules(Collections.singletonList(rule));

或者使用控制台形式添加热词限流规则

正常编写Java接口

@RequestMapping("/getUserOrder")
@SentinelResource(value = "getUserOrder")
public String getUserOrder(Long userId) {
    return "根据userId获取用户订单信息成功";
}

索引名:参数下表从 0 开始

单机阈值:单机部署时在统计时间内可以访问多少次

统计窗口时长:统计热词的时间

可以给指定的参数额外设定阈值:例如:VIP用户拥有特定的标识,判断为VIP用户时,可以请求接口的次数增加。

到此这篇关于Sentinel热门词汇限流的实现详解的文章就介绍到这了,更多相关Sentinel热词限流内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Sentinel热门词汇限流的实现详解

本文链接: https://lsjlt.com/news/165572.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作