高并发下的秒杀、抢东西

5 篇文章 0 订阅

这里以TP框架为例子:

一、利用MYSQL锁表的功能

这个方法核心就是锁表和解锁:

// 这里锁定tests表
M()->execute('LOCK TABLES tests WRITE');

$data = M('tests')->find(1);
if ($data['counts'] > 0 && M('tests')->where('id=1')->setDec('counts')) {
    // 抢成功了
} else {
    // 抢失败了
}

// 操作完之后解开锁
M()->execute('UNLOCK TABLES');

二、在SQL语句上面做文章

相比上面的方法,效率更高(核心:counts > 0(被减少的字段必须 >0)):

// 这里主要利用了 `counts` 字段,SQL如果有修改会返回修改的条数,当 `counts` 字段减少到 0 的时候再减就会返回修改的条数为 0 ,根据返回的修改条数的判断也能实现是否抢成功
if (M('tests')->where('id=1 and counts > 0')->setDec('counts')) {
    // 抢成功了
} else {
    // 抢失败了
}

三、利用redis进行锁定

这里不写具体实现方式,大概原理:

  1. redis 发起锁单请求。
  2. redis返回结果为1表示锁单成功(执行业务逻辑),0表示已经被上锁(不能执行业务逻辑)。
  3. 业务逻辑执行完了向 redis 发送一个开锁的请求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值