摘要:前面寫過利用文件鎖來處理高并發(fā)的問題的,現(xiàn)在我們說另外一個處理方式,利用的鎖來解決高并發(fā)的問題先看沒有利用事務(wù)的時候并發(fā)的后果創(chuàng)建庫存管理表創(chuàng)建訂單管理表測試代碼我們預(yù)置庫存是十個,然后執(zhí)行測試查看結(jié)果
前面寫過利用文件鎖來處理高并發(fā)的問題的,現(xiàn)在我們說另外一個處理方式,利用Mysql的鎖來解決高并發(fā)的問題
創(chuàng)建庫存管理表
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
創(chuàng)建訂單管理表
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); } }
我們預(yù)置庫存是十個,然后執(zhí)行ab測試查看結(jié)果
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();//開啟事務(wù) $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();//提交事務(wù) } else { $pdo->rollBack();//回滾 } } else { $pdo->rollBack();//回滾 } }
查看結(jié)果
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鎖之后,對庫存進(jìn)行了有效的控制,很好的解決了第一段代碼里面,因為并發(fā)引起的一些邏輯性的問題
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/29399.html
摘要:一為什么難秒殺系統(tǒng)難做的原因庫存只有一份,所有人會在集中的時間讀和寫這些數(shù)據(jù)。又例如搶票,亦與秒殺類似,瞬時流量更甚。 一、為什么難 ????秒殺系統(tǒng)難做的原因:庫存只有一份,所有人會在集中的時間讀和寫這些數(shù)據(jù)。例如小米手機(jī)每周二的秒殺,可能手機(jī)只有1萬部,但瞬時進(jìn)入的流量可能是幾百幾千萬。又例如12306搶票,亦與秒殺類似,瞬時流量更甚。 主要需要解決的問題有兩個: 高并發(fā)對數(shù)據(jù)庫...
摘要:以購買商品舉例從數(shù)據(jù)庫獲取庫存的數(shù)量。這里暫時就不測試了,下面會針對并發(fā)的處理給出測試結(jié)果。第二種方案,使用的文件鎖。特點(diǎn)當(dāng)調(diào)用鎖一個文件時,如果沒有獲取鎖,直接返回,不會出現(xiàn)阻塞。的表鎖和的文件鎖在應(yīng)對并發(fā)數(shù)量上也有差別,自己可以多測試。 以購買商品舉例: ① 從數(shù)據(jù)庫獲取庫存的數(shù)量。② 檢查一下庫存的數(shù)量是否充足。③ 庫存的數(shù)量減去買家購買的數(shù)量(以每個用戶購買一個為例)。④ 最后...
閱讀 1918·2021-09-23 11:21
閱讀 1704·2019-08-29 17:27
閱讀 1062·2019-08-29 17:03
閱讀 729·2019-08-29 15:07
閱讀 1926·2019-08-29 11:13
閱讀 2384·2019-08-26 12:14
閱讀 927·2019-08-26 11:52
閱讀 1736·2019-08-23 17:09