高併發下的秒殺、搶東西

這裏以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 發送一個開鎖的請求。
發佈了66 篇原創文章 · 獲贊 8 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章