参与过抢购活动就知道,很明显的一点是商即使商品实际没有了也是能够下单成功的,可是在支付的时候会提示你商品没有了。mysql
实现原理:list双向链表redis
使用redis队列,由于pop操做是原子的,即便有不少用户同时到达,也是依次执行.(mysql事务在高并发下性能降低很厉害,文件锁的方式也是).sql
此处用到了Redis中的链表(list)数据类型:缓存
'栈':从链表的头部添加元素,先进后出并发
'队列':从链表的尾部添加元素,先进先出高并发
redis保存数据时都有key和value,key和value要么是String类型的,要么是byte[]类型的性能
第一步:先将商品库存存入队列blog
第二步:抢购开始,设置库存的缓存周期队列
第三步:客户端执行下单操做,下单前判断redis队列库存量事务