python实现redis三种cas事务操作
289
2022-07-22
参与过抢购活动就知道,很明显的一点是商即便商品实际没有了也是可以下单成功的,但是在支付的时候会提示你商品没有了。
实现原理:list双向链表
使用redis队列,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行.(mysql事务在高并发下性能下降很厉害,文件锁的方式也是).
此处用到了Redis中的链表(list)数据类型:
'栈':从链表的头部添加元素,先进后出
'队列':从链表的尾部添加元素,先进先出
redis保存数据时都有key和value,key和value要么是String类型的,要么是byte[]类型的
第一步:先将商品库存存入队列
$result = $redis->connect("127.0.0.1",6379); //设置100件商品库存 $goods_number = 100; //将100件商品存入到Redis链表中 for($i=0;$i<$goods_number;$i++){
//lpush从链表的头部添加元素 $redis->lpush('goods_store',1);
} //llen返回列表key的长度 echo $redis->llen('goods_store'); ?>
第二步:抢购开始,设置库存的缓存周期
setTimeout('goods_store',60); ?>
第三步:客户端执行下单操作,下单前判断redis队列库存量
$redis->connect("127.0.0.1",6379); //从链表的头部删除一个元素,返回删除的元素,$count为true $count = $redis->lpop('goods_store'); if(!count){
echo "抢购失败";
return;
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~