currentTimeMillis+原子计数器实现限流方法
时间:2026-05-29 11:09:45 330浏览 收藏
本文深入探讨了如何利用System.currentTimeMillis()与原子计数器(如AtomicInteger)协同实现高效、可靠的单机限流,核心在于通过时间戳对齐固定窗口、借助原子操作保障并发安全计数,并精细把控阈值判断时机(getAndIncrement或incrementAndGet)、惰性清理过期窗口以避免内存膨胀,同时直面固定窗口固有的“双倍突刺”问题,提出缩窗、滑动窗口或令牌桶等进阶方案,为高并发场景下的精准限流提供了兼具实用性与深度的技术实践指南。

用 System.currentTimeMillis() 配合原子计数器做单机限流,核心是靠时间戳判断是否进入新窗口,并用 AtomicInteger 或 AtomicLong 安全累加请求数。关键不在“能不能用”,而在于“怎么用才不漏、不超、不卡死”。
用时间戳划分固定窗口
把每秒(或每 N 毫秒)看作一个独立计数周期。每次请求来时,先算出当前所属的时间窗口起点,比如:
- 按秒切分:窗口 key =
System.currentTimeMillis() / 1000 - 按 500ms 切分:窗口 key =
System.currentTimeMillis() / 500
这个 key 决定了该请求归入哪个计数桶。注意:除法结果是向下取整,天然对齐窗口边界。
用原子变量安全计数
不能用普通 int 加 ++,因为读-改-写三步非原子,高并发下会丢计数。必须用:
AtomicInteger.incrementAndGet()—— 先加再返回,适合“加完立刻判断”场景AtomicInteger.getAndIncrement()—— 先返回再加,适合“加前判断阈值”逻辑
例如:if (counter.getAndIncrement() 表示“如果加之前还没到上限,就放行”。
清理过期窗口要克制
窗口只保留最近几个(如当前 + 前 1 秒),老的 key 要删,否则 map 无限膨胀。但别每次请求都遍历清理:
- 推荐惰性清理:在插入新 key 前,顺手删掉
key < nowSecond - 1的旧项 - 或用定时任务(如 ScheduledExecutorService)每秒扫一次,避免请求线程阻塞
- 绝对不要在
tryAcquire()里调map.keySet().removeIf(...)—— 这会锁整个 map,拖慢所有请求
警惕窗口切换的临界问题
固定窗口天然存在“双倍突刺”风险:比如 0.9s 到 1.0s 放行了 100 次,1.0s 瞬间重置,1.0s 到 1.1s 又放行 100 次 → 实际 0.2s 内来了 200 次。这不是 bug,是算法特性。
若业务敏感(如支付、库存扣减),就得升级方案:
- 改用滑动窗口(维护多个子窗口,按时间加权)
- 或直接上令牌桶(允许平滑突发,更适合真实流量)
- 单机场景下,也可折中:把窗口缩到 200ms,用 5 个桶滚动计数,精度提升,开销可控
今天关于《currentTimeMillis+原子计数器实现限流方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
124 收藏
-
453 收藏
-
423 收藏
-
297 收藏
-
154 收藏
-
389 收藏
-
267 收藏
-
123 收藏
-
395 收藏
-
484 收藏
-
192 收藏
-
248 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习