Redis.Decr原子扣库存可防超卖,需配合过期设置、失败回滚、SETNX防重、channel限流及异步落单。用 redis.Decr 原子扣库存,别写"先查后减" SQL高并发下秒杀失败或超卖,八成出在库存校验逻辑上。最典型错误是两行 SQL:SELECT stock FROM seckill_goods WHERE id=? 然后判断再 UPDATE SET stock=stock-1------中间任何并发请求都会绕过检查。正确做法是把"判断 + 扣减"压进一条原子操作。redis.Decr 天然支持:它返回扣减后的值,你只需检查是否 ≥0 就能确认成功与否。Decr 是线程安全的,不依赖客户端加锁,也不受 Go 协程调度影响务必设置 key 过期时间,例如:SETEX seckill:stock:123 3600 100,避免场次结束库存残留扣减失败时要立刻 Incr 回滚,否则库存会永久变负(尤其在 panic 或网络中断时)用 SETNX 防重复下单,别信前端 disabled 或 session用户刷新页面、F5 重发、脚本模拟,都可能让同一个账号多次提交。只校验登录态或前端按钮置灰毫无意义。必须在服务端做幂等控制,推荐用 Redis SETNX(set if not exists)打唯一标记:立即学习"go语言免费学习笔记(深入)"; Zeemo AI 一款专业的视频字幕制作和视频处理工具