当前位置: 首页 > news >正文

【PmHub面试篇】PmHub中基于Redis加Lua脚本的计数器算法限流实现面试专题解析

你好,欢迎来到本次关于PmHub中基于Redis加Lua脚本的计数器算法限流实现的面试系列分享。在这篇文章中,我们将深入探讨这一技术领域的相关面试题预测。若想对相关内容有更透彻的理解,强烈推荐参考之前发布的博文:【PmHub后端篇】PmHub中基于Redis加Lua脚本的计数器算法限流实现

1 什么是限流?在什么场景下需要使用限流?

  • 限流是一种控制流量的方法,主要用于防止系统过载,保障服务的稳定性
  • 在高并发场景下,比如电商秒杀、抢购活动等,我们需要限流来防止系统被突发的大量请求压垮

2 常用算法有哪些?

常用算法包括计数器、滑动窗口、漏桶、令牌桶等。

限流算法原理优点缺点
计数器(Counter)法在固定时间窗口内统计请求数,超过阈值则拒绝请求实现简单,适用于固定时间窗口的流量控制无法处理突发流量
滑动窗口计数器法将固定时间窗口分成多个小窗口,通过滑动小窗口动态统计总请求数平滑处理流量,比固定窗口更有效实现复杂度较高
漏桶(Leaky Bucket)算法请求进入漏桶,漏桶以恒定速率出水,当桶满时新的请求被丢弃平滑突发流量,严格控制请求处理速率可能导致请求延迟增加
令牌桶(Token Bucket)算法系统按恒定速率生成令牌,请求消耗令牌,当没有令牌时请求被拒绝或排队允许突发流量处理,能长期控制处理速率实现相对复杂,需要管理令牌
漏桶与令牌桶的组合将漏桶与令牌桶结合,既能控制平均速率,又能应对突发流量综合两者优点,既能平滑流量又能应对突发流量实现复杂度更高

3 能简要介绍一下计数器算法的基本原理吗?

  • 计数器算法的基本原理是在固定时间窗口内对请求次数进行计数
  • 如果请求次数超过设定的阈值,就拒绝后续的请求。这个时间窗口可以是1秒、1分钟等。

4 为什么选择 Redis+Lua 实现限流?

  • Redis具有高性能、单线程的特点,能够处理高并发请求
  • 同时,Redis提供了丰富的数据结构和原子操作,使得限流算法的实现更加简单高效
  • Lua 脚本减少网络交互次数,并通过原子性避免并发问题。
  • 相比本地缓存(如 Guava),Redis 支持跨服务实例的统一限流,更适合微服务架构。

5 您是如何在Redis中实现计数器算法的限流的?能详细描述一下实现过程吗?

  • 注解+AOP 切面+Lua 脚本
  • 用自己理解的话来描述,具体应用场景,在登录接口添加限流。
  • 简述实现过程:定义限流配置(RedisConfig)->自定义限流注解->AOP 切面实现限流逻辑-> 登录接口应用注解

6 登录接口为何需要单独限流?

  • 登录接口通常配置在网关白名单,绕过网关认证,无法被全局限流捕获
  • 登录接口易被暴力破解或高频刷取,需独立防护。通过 Redis+Lua 可精准限制单个用户 / IP 的请求频率。

7 您是如何处理并发请求的?在高并发场景下,限流策略是否依然有效?

  • 通过Redis单线程的特点和Lua脚本的原子性来处理并发请求,确保计数器的准确性。
  • 在高并发场景下,限流策略依然有效,因为Redis的高性能和Lua脚本的原子操作可以应对大量请求

8 有自己压测过吗?怎么压测的?

  • 有, 使用JMeter发送1秒10个请求, 或者1秒100请求等
  • 在不同的并发请求下, 所得出的结果均符合预期

9 当限流计数器达到上限时,您是如何处理用户请求的?是否有备用方案?

  • 计数器达到上限时,我们会拒绝后续的请求,并返回一个友好的错误信息
  • 同时,我们会记录这些被拒绝的请求,以便后续进行分析和调整限流策略

10 参考链接

  1. PmHub实现Redis加Lua脚本基于计数器算法的限流
  2. Redis+Lua登录限流相关
http://www.lqws.cn/news/177661.html

相关文章:

  • 数据库SQLite基础
  • Ubuntu18.6 学习QT问题记录以及虚拟机安装Ubuntu后的设置
  • 【Qt】:设置新建类模板
  • C/C++ 面试复习笔记(4)
  • Excel 发现此工作表中有一处或多处公式引用错误。请检查公式中的单元格引用、区域名称、已定义名称以及到其他工作簿的链接是否均正确无误。弹窗
  • 关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案
  • excel数据对比找不同:6种方法核对两列数据差异
  • 天机学堂(学习计划和进度)
  • 内容力重塑品牌增长:开源AI大模型驱动下的智能名片与S2B2C商城赋能抖音生态种草范式
  • ESP8266(NodeMcu)+GPS模块+TFT屏幕实现GPS码表
  • 【PhysUnits】16.1 完善Var 结构体及其运算(variable.rs)
  • 多种风格导航菜单 HTML 实现(附源码)
  • 32单片机——基本定时器
  • 基于springboot的校园社团信息系统的设计与实现
  • 【案例分享】如何借助JS UI组件库DHTMLX Suite构建高效物联网IIoT平台
  • golang入门
  • 前端中slice和splic的区别
  • # 从底层架构到应用实践:为何部分大模型在越狱攻击下失守?
  • 2025/6/4—halcon算子及知识点总结
  • 【前端】每日一道面试题6:解释Promise.any和Promise.allSettled的使用场景及区别。
  • Linux-http协议
  • 全新Xsens Animate版本是迄今为止最大的软件升级,提供更清晰的数据、快捷的工作流程以及从录制开始就更直观的体验
  • 免费 + 通用 + 高效!UniHarp数据采集软件上线了!
  • F5 GSLB 最佳实践:如何手动将Wide IP 故障转移到另一个数据中心
  • 【八股消消乐】MySQL参数优化大汇总
  • Linux top 命令 的使用总结
  • ngx_stream_access_module基于 IP 的流式访问控制实践指南
  • spring:实例化类过程中方法执行顺序。
  • 【idea】分享一个关于Maven依赖管理好用的插件
  • Caliper 负载(Workload)详细解析