昨天面试的时候,被面试官问到库存扣减问题。。。估计面试官把我的项目当成秒杀了。。怪我自己没介绍清楚项目,自己挖坑。。。
今天在博客上看了一些关于库存扣减问题,主要还是觉得比较合适的方式就是使用redis分布式锁,这是最简单的方案,但是如果事务过大,会有性能问题.操作不当,会有死锁问题
基于redis setnx的简易分布式锁
如果两个线程同时执行的话会出现超卖问题
所以我们要加个锁
但这样在并发量很高的时候,是不合适的,所以,可以考虑库存占用
二、在Redis中扣减库存
InnoDB的行锁特性其实是一把利与弊都同样明显的双刃剑,在保证一致性的同时却降低了可用性,那么究竟应该如何保证大并发更新热点数据不会导致数据库沦为瓶颈,这其实是秒杀、抢购场景下最核心的技术难题之一。可以尝试将热卖商品的库存扣减操作转移至数据库外,由于Redis的读/写能力要远胜过任何类型的关系型数据库,因此在Redis中实现库存扣减将会是一个不错的替代方案,这样一来,数据库中存储的商品库存可以理解为实际库存,而Redis中存储的商品库存则为实时库存。
1.先查询redis