Python 官方文档:入门教程 => 点击学习
目录热点参数限流基本使用热点参数限流 何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如: 商品 ID 为参
何为热点?热点即经常访问的数据。很多时候我们希望统计某个热点数据中访问频次最高的 Top K 数据,并对其访问进行限制。比如:
热点参数限流会统计传入参数中的热点参数,并根据配置的限流阈值与模式,对包含热点参数的资源调用进行限流。热点参数限流可以看做是一种特殊的流量控制,仅对包含热点参数的资源调用生效。
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
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0