下面由laravel教程欄目給大家介紹使用laravel解決庫存超出的幾個方案,希望對需要的朋友有所幫助!
1.錯誤的示范
/** * 錯誤示范 * Create by Peter Yang * 2021-06-08 10:57:59 * @return string */ function test1() { //商品id $id = request()->input('id'); $product = Product::where('id', $id)->firstOrFail(); if ($product->num <= 0) { return "賣光啦?。?quot;; } //倉庫減1 $product->decrement('num'); return "success"; }
使用go模擬并發(fā)
package mainimport ( "fmt" "github.com/PeterYangs/tools/http" "sync")func main() { client := http.Client() wait := sync.WaitGroup{} for i := 0; i < 50; i++ { wait.Add(1) go func(w *sync.WaitGroup) { defer wait.Done() res, _ := client.Request().GetToString("http://www.api/test1?id=1") fmt.Println(res) }(&wait) } wait.Wait()}
在數(shù)據(jù)庫中查看庫存
庫存已超出
2.redis原子鎖
/** * redis原子鎖 * Create by Peter Yang * 2021-06-08 11:00:31 */ function test2() { //商品id $id = request()->input('id'); $lock = Cache::lock("product_" . $id, 10); try { //最多等待5秒,5秒后未獲取到鎖,則拋出異常 $lock->block(5); $product = Product::where('id', $id)->firstOrFail(); if ($product->num <= 0) { return "賣光啦??!"; } //倉庫減1 $product->decrement('num'); return 'success'; }catch (LockTimeoutException $e) { return '當(dāng)前人數(shù)過多'; } finally { optional($lock)->release(); } }
庫存正常
3.mysql悲觀鎖
/** * mysql悲觀鎖 * Create by Peter Yang * 2021-06-08 11:00:47 */ function test3() { //商品id $id = request()->input('id'); try { DB::beginTransaction(); $product = Product::where('id', $id)->lockForUpdate()->first(); if ($product->num <= 0) { return "賣光啦??!"; } //倉庫減1 $product->decrement('num'); DB::commit(); return "success"; } catch (Exception $exception) { } }
庫存正常
4.mysql樂觀鎖
/** * mysql樂觀鎖 * Create by Peter Yang * 2021-06-08 11:00:47 */ function test4() { //商品id $id = request()->input('id'); $product = Product::where('id', $id)->first(); if ($product->num <= 0) { return "賣光啦!!"; } //修改前檢查庫存和之前是否一致,不一致說明已經(jīng)有變動,則放棄更改 $res = DB::update('UPDATE `product` SET num = num -1 WHERE id = ? AND num=?', [$id, $product->num]); if (!$res) { return '當(dāng)前人數(shù)過多'; } return 'success'; }
庫存正常
優(yōu)化樂觀鎖
修改庫存的sql修改為
DB::update('UPDATE `product` SET num = num -1 WHERE id = ? AND num-1 >= 0', [$id]);
? 版權(quán)聲明
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載。
THE END
喜歡就支持一下吧
相關(guān)推薦