利用乐观锁及redis解决电商秒杀高并发基本逻辑

Posted life_lt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用乐观锁及redis解决电商秒杀高并发基本逻辑相关的知识,希望对你有一定的参考价值。

解决秒杀高并发问题方法很多,如悲观锁,消息队列等……

利用乐观锁及redis解决秒杀高并发基本逻辑

//初始化redis

$redis = new Redis();

// 设置键值,起到监视作用  执行事务之前,判断被修改,回滚

$redis->watch(‘sales‘);

// 获取销量

$sales = $redis->get(‘sales‘);

// 如果销量存在,先删除,false

// $redis->del(‘sales‘);

// 库存,秒杀两件产品

$store = 2;

// 判断销量是否大于等于库存

if($sales >= $store){
    // 结束
    exit(‘活动结束‘);
}

// 事务块内多条命令会按先后顺序放入一个队列中,最后有EXEC命令原子性的执行

//redis开启事务

$reids->multi();

// 更新销量

$redis->set(‘sales‘, $sales+1);

$res = $redis->exec();

// 记录到redis里面,用守护进程 swoole多进程去执行 !!!

if($res){
    // 减库存冀其他操作
}

以上是关于利用乐观锁及redis解决电商秒杀高并发基本逻辑的主要内容,如果未能解决你的问题,请参考以下文章

Redis高并发场景下秒杀超卖解决

视频 |电商平台Redis高并发秒杀超卖实战

如何解决高并发秒杀的超卖问题

十万级低成本超详细的秒杀高并发设计,快收藏起来

高并发之商品秒杀系统

使用 Redis 助力高并发电商秒杀系统