摘要:前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用的鎖來解決高并發的問題先看沒有利用事務的時候并發的后果創建庫存管理表創建訂單管理表測試代碼我們預置庫存是十個,然后執行測試查看結果
前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用Mysql的鎖來解決高并發的問題
創建庫存管理表
CREATE TABLE `storage` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `number` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1
創建訂單管理表
CREATE TABLE `order` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `number` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=latin1
測試代碼
$pdo = new PDO("mysql:host=127.0.0.1;port=3306; dbname=test","root","123456"); $sql="select `number` from storage where id=1 limit 1"; $res = $pdo->query($sql)->fetch(); $number = $res["number"]; if($number>0) { $sql ="insert into `order` VALUES (null,$number)"; $order_id = $pdo->query($sql); if($order_id) { $sql="update storage set `number`=`number`-1 WHERE id=1"; $pdo->query($sql); } }
我們預置庫存是十個,然后執行ab測試查看結果
mysql> select * from storage -> ; +----+--------+ | id | number | +----+--------+ | 1 | -2 | +----+--------+ 1 row in set (0.00 sec) mysql> select * from `order`; +----+--------+ | id | number | +----+--------+ | 22 | 10 | | 23 | 10 | | 24 | 8 | | 25 | 8 | | 26 | 7 | | 27 | 6 | | 28 | 4 | | 29 | 3 | | 30 | 2 | | 31 | 2 | | 32 | 2 | | 33 | 1 | +----+--------+ 12 rows in set (0.00 sec)
得到了訂單共有12個,而庫存表的庫存也減到了-2,這顯然不符合實際邏輯的;
修改代碼如下
$pdo = new PDO("mysql:host=127.0.0.1;port=3306; dbname=test","root","123456"); $pdo->beginTransaction();//開啟事務 $sql="select `number` from storage where id=1 for UPDATE ";//利用for update 開啟行鎖 $res = $pdo->query($sql)->fetch(); $number = $res["number"]; if($number>0) { $sql ="insert into `order` VALUES (null,$number)"; $order_id = $pdo->query($sql); if($order_id) { $sql="update storage set `number`=`number`-1 WHERE id=1"; if($pdo->query($sql)) { $pdo->commit();//提交事務 } else { $pdo->rollBack();//回滾 } } else { $pdo->rollBack();//回滾 } }
查看結果
mysql> select * from storage; +----+--------+ | id | number | +----+--------+ | 1 | 0 | +----+------ --+ 1 row in set (0.00 sec) mysql> select * from `order`; +----+--------+ | id | number | +----+--------+ | 1 | 10 | | 2 | 9 | | 3 | 8 | | 4 | 7 | | 5 | 6 | | 6 | 5 | | 7 | 4 | | 8 | 3 | | 9 | 2 | | 10 | 1 | +----+--------+ 10 rows in set (0.00 sec)
很明顯在利用了mysql鎖之后,對庫存進行了有效的控制,很好的解決了第一段代碼里面,因為并發引起的一些邏輯性的問題
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/29399.html
摘要:一為什么難秒殺系統難做的原因庫存只有一份,所有人會在集中的時間讀和寫這些數據。又例如搶票,亦與秒殺類似,瞬時流量更甚。 一、為什么難 ????秒殺系統難做的原因:庫存只有一份,所有人會在集中的時間讀和寫這些數據。例如小米手機每周二的秒殺,可能手機只有1萬部,但瞬時進入的流量可能是幾百幾千萬。又例如12306搶票,亦與秒殺類似,瞬時流量更甚。 主要需要解決的問題有兩個: 高并發對數據庫...
摘要:以購買商品舉例從數據庫獲取庫存的數量。這里暫時就不測試了,下面會針對并發的處理給出測試結果。第二種方案,使用的文件鎖。特點當調用鎖一個文件時,如果沒有獲取鎖,直接返回,不會出現阻塞。的表鎖和的文件鎖在應對并發數量上也有差別,自己可以多測試。 以購買商品舉例: ① 從數據庫獲取庫存的數量。② 檢查一下庫存的數量是否充足。③ 庫存的數量減去買家購買的數量(以每個用戶購買一個為例)。④ 最后...
閱讀 1914·2021-09-23 11:21
閱讀 1700·2019-08-29 17:27
閱讀 1058·2019-08-29 17:03
閱讀 728·2019-08-29 15:07
閱讀 1921·2019-08-29 11:13
閱讀 2381·2019-08-26 12:14
閱讀 921·2019-08-26 11:52
閱讀 1732·2019-08-23 17:09