golang如何实现滑动窗口计数器_golang滑动窗口计数器实现思路

滑动窗口计数器不能只用map+定时清理,因会漏统计非整点对齐的请求;必须保留带时间戳事件或时间分片,常用环形数组实现,按需shift比ticker更精准高效。滑动窗口计数器为什么不能只用 map + 定时清理直接用 mapstringint 存请求次数、再起 goroutine 每秒删过期 key,看似简单,但会漏统计。比如窗口是 60 秒,当前时间戳是 1717023450,你只保留 key 对应的"最后更新时间",那 1717023400~1717023449 这 50 秒内的请求就全算不到当前窗口里------因为它们在定时清理时被删了,而新请求还没触发重置逻辑。本质问题是:滑动窗口要求"任意时刻往前推 N 秒"的累计值,不是"整点对齐的桶"。必须保留带时间戳的原始事件,或至少保留足够粒度的时间分片。用环形数组 + 时间分片实现低开销滑动窗口最常用且平衡内存与精度的做法:把窗口切分成固定数量的 slot(如 60 秒窗口切 60 个 1 秒 slot),用环形数组存每个 slot 的计数,再记录每个 slot 对应的起始时间戳。每次计数前先滑动指针、清空已过期 slot。slotDuration 要能整除窗口时长,否则边界计算易错;推荐用 1s/100ms 级别数组长度 = windowSeconds / slotDuration,必须是整数,否则向下取整后窗口实际变短每次 Inc() 前先调用 shift() 检查当前 slot 是否已过期,过期则归零并移动索引并发安全需用 sync.RWMutex 或 atomic 操作 slot 内计数(如果 slot 元素是 uint64)type SlidingWindowCounter struct { slots \[\]uint64 timestamps \[\]int64 slotDur int64 // 单位:毫秒 windowDur int64 // 单位:毫秒 size int mu sync.RWMutex currentIndex int}<p>func (c *SlidingWindowCounter) Inc() {c.mu.Lock()defer c.mu.Unlock()now := time.Now().UnixMilli()c.shift(now)atomic.AddUint64(&c.slotsc.currentIndex, 1)}</p><p>func (c *SlidingWindowCounter) shift(now int64) {slotStart := now - (now % c.slotDur)for (now - c.timestampsc.currentIndex) >= c.windowDur {c.slotsc.currentIndex = 0c.timestampsc.currentIndex = slotStartc.currentIndex = (c.currentIndex + 1) % c.sizeslotStart += c.slotDur}}time.Ticker 驱动清理 vs 按需 shift 的取舍有人用 time.Ticker 每 100ms 触发一次全局 slot 清理,看起来更"主动",但实际引入额外 goroutine 和锁竞争,且无法保证清理时机与请求到达严格同步------可能刚清完一个 slot,下一毫秒就来 1000 个请求,导致瞬时计数虚高。立即学习"go语言免费学习笔记(深入)"; Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

相关推荐
NiceCloud喜云2 分钟前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
ccddsdsdfsdf18 分钟前
DBeaver怎么链接mongoDB
数据库·mongodb
AI玫瑰助手35 分钟前
Python函数:默认参数的定义与注意事项
开发语言·python·信息可视化
weixin_4684668539 分钟前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
小糖学代码1 小时前
LLM系列:环境搭建:5.Python-dotenv 环境变量管理
人工智能·python·深度学习·神经网络
丷丩1 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空991 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
智慧物业老杨2 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
橙橙笔记2 小时前
Python的学习第一部分
python·学习
TheRouter2 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle