面试场景题

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

在刷短视频的时候碰到了这样一个场景题,一时想不出。"10W个请求,QPS1W,抢100件商品,不许超卖"


一、解答

1.面对10W个请求和1WQPS,第一步就是限流,削峰填谷。

2.第二步开始处理,面对100件商品的加减,这属于小数量的加减,可以考虑用单线程来完成,lua刚好是单线程的,所以这里用lua一个个减,注意不要写循环。

lua 复制代码
-- KEYS[1] = stockKey
-- KEYS[2] = orderSetKey
-- ARGV[1] = userId

local stock = tonumber(redis.call("GET", KEYS[1]))
if not stock or stock <= 0 then
    return -1  -- 已售罄
end

-- 判断是否已下单
if redis.call("SISMEMBER", KEYS[2], ARGV[1]) == 1 then
    return -2  -- 重复下单
end

-- 扣库存
redis.call("DECR", KEYS[1])

-- 记录用户
redis.call("SADD", KEYS[2], ARGV[1])

return 1  -- 成功

3.数据持久化

二、解答思想

我一开始考虑用什么中间件,后来想来想去还是传统的redis+mysql,因为redis是基于内存的,够快。后来想到为了保证同一时间只有一个线程操控数据应该加锁,可能就是加分布式锁,这里忘记了分布式锁就是redis或者zookeeper。想法比较简单。

分布式锁要经过3次rpc:加锁、操作、解锁并且是阻塞运行的;而lua是原子性操作只有一次rpc并且是非阻塞,虽然是单线程,但是没有等待时间。

什么时候用分布式锁,什么时候用lua:

分布式锁保证单实例,lua保证原子性;防止重复提交,多台机器布置定时任务,保证不重复前提交,用分布式锁;多个服务同时读写同一条数据,用分布式锁;代码逻辑复杂,包括多个步骤,用分布式锁。保证原子性操作、减少网络开销、批量处理数据用lua。


总结

相关推荐
ricardo19731 小时前
防抖节流进阶 + requestAnimationFrame:滚动与输入场景的性能优化
前端·面试
自进化Agent智能体2 小时前
拆解Hermes会话循环:一个目标如何变成可执行的代码
面试
是小王同学啊~3 小时前
Kafka 面试通关笔记:高频八股 + 生产实战 + 追问链路(上)
笔记·面试·kafka
ychqsq4 小时前
39.新年
经验分享·职场和发展
我命由我123454 小时前
UGC、PGC、PUGC 极简理解
经验分享·笔记·学习·职场和发展·求职招聘·职场发展·学习方法
Komorebi_99994 小时前
Day6:微调 vs RAG 场景区分(面试高频)
面试·职场和发展
英俊潇洒美少年4 小时前
Vue2 $set 深度解析 + 批量更新全套优化方案(原理+实战+踩坑+面试)
面试·职场和发展·wps
Xzh04234 小时前
Redis黑马点评 实战复盘与面试高频考点详解
java·数据库·redis·面试
SiYuanFeng5 小时前
百度网盘【搜索/查找】如何限定在当前文件夹下搜索
面试