您现在的位置是:亿华云 > 人工智能
互联网大厂面试:如何利用Redis实现全局接口限流
亿华云2025-10-03 20:26:24【人工智能】9人已围观
简介前言对于某些特殊的业务场景,比如抢单、秒杀等业务,会导致服务流量瞬间飙升,我们虽然可以通过部署集群的方式分散请求压力,但是仍然可能造成很大的请求延迟。这时,我们可以通过接口限流的方式来保证系统的稳定运
前言
对于某些特殊的互联业务场景,比如抢单、厂面秒杀等业务,试何s实会导致服务流量瞬间飙升,利用流我们虽然可以通过部署集群的现全方式分散请求压力,但是局接仍然可能造成很大的请求延迟。
这时,口限我们可以通过接口限流的互联方式来保证系统的稳定运行。
实现逻辑
我们可以通过filter对所有的厂面接口进行拦截,网站模板判断这个接口在当前时间窗口内的试何s实请求次数,如果超出我们设定的利用流请求上限,就返回无效请求。现全
以限制每个接口最大为10个QPS为例,局接可以有两种实现逻辑:
其一,口限将这10个请求进行拆分,互联相当于每100ms可以请求一次。
其二,每秒内最多请求10次,而不判断其请求分布范围。
两种逻辑的实现也略有差异。
实现一
每秒请求一次。香港云服务器
实现二
每秒请求N次。
判断每秒请求N次会比每秒一次稍微复杂一点,主要是需要判断当前秒内已经请求了多少次。
这里利用redis的increment和expire配合使用达到限流的目的。
以限制每秒5次为例:
总结
以上两种利用redis实现限流的方式基本能满足我们大部分的业务需要,对于部分要求限流粒度更高更准的业务,可以引入sentinel来满足业务需要。
云南idc服务商很赞哦!(43898)
相关文章
热门文章
站长推荐
前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。
Windows Server 2016 服务器配置指南 之 MariaDB数据库环境搭建方法
域名续费多少钱一年?
SpringBoot整合分布式消息平台Pulsar
2、根据用户基础选择访问提供程序。由于互联问题的存在,接入商的选择也非常重要,如果用户群主要在联通,尽量选择联通接入较好的接入商,如果用户群主要在电信,那么选择电信接入较好的接入商。如果用户组位于国家/地区,则选择更好的访问提供程序进行交互。
Oracle故障处理Rman-06207&Rman-06214的方法
Chrome 的后悔药,推荐一枚有用的插件
聊聊DP入门之整数拆分!