php商城秒殺功能怎麼實現

2022-10-18 14:00:51

php商城秒殺功能的實現方法:1、開啟php檔案,連線redis資料庫;2、建立待搶購商品的list列表;3、模擬使用者請求並設定隨機獲取10名使用者表示搶購成功;4、判斷搶購列表中是否已存在該使用者並獲取列表中所有的資料;5、將redis中已搶購的使用者儲存到資料庫中即可。

CRMEB開源商城系統,開源無加密+免費商用+檔案齊全+二開便捷:免費下載
系統採用前後端分離技術,基於TP6+Uni-app框架開發;
客戶行動端採用uni-app開發,管理後臺前端使用iviewUI開發;
系統支援微信公眾號端、微信小程式端、H5端、PC端多端賬號同步,可快速打包生成APP;

本教學操作環境:windows7系統、PHP8.1版、DELL G3電腦

php+redis實現秒殺功能,可緩解瞬時並行對mysql的壓力

場景:在某個時間點對商品goods_id=2的商品進行搶購,商品庫存為10

建立商品goods_id=2的庫存搶購列表

首先建立待搶購商品的list列表,如果有人搶購成功就移除一個,直到列表為空則表示搶購完成。

//1、連線redis資料庫
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品參與秒殺
//2、模擬搶購,庫存為10,將庫存放到redis中
$num = 10;
for($i=0;$i<$num;$i++){
$redis->lPush($redis_name,1);//這裡用某個商品的ID作為標識
}
echo "執行成功";
登入後複製
344dd9459e2861dff42496809e3b36b.jpg

使用者端進行模擬搶購

//1、連線redis資料庫
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品參與秒殺
//3、模擬使用者請求,隨機獲取10名使用者表示搶購成功
for($i=0;$i<100;$i++){
$user_id = rand(100,999);
$len = $redis->lLen($redis_name);
$str = "";
if(!$len || $len<=0){
$str .= $user_id."搶購已結束";
break;
}else{
$redis_user_name = "goods_id_2_user_id";
//判斷搶購列表中是否已存在該使用者,獲取列表中所有的資料
$skill_list = $redis->lrange($redis_user_name, 0, -1);
if(in_array($user_id, $skill_list)){
$str .= $user_id."請勿重複提交";
}else{
$redis->rPop($redis_name);
$redis->lPush($redis_user_name,$user_id."_".ceil(microtime(true)*1000));
$str .= $user_id."已搶到";
}
}
file_put_contents("D:/wwwroot/test/skill/cron.txt", $str."\r\n",FILE_APPEND);
}
echo '執行完成';
登入後複製
4dc1f7a19452bc76d3bafb973d99358.jpg

伺服器端執行佇列處理,將redis中已搶購的使用者儲存到資料庫中

<?php
$mysql_server_name = 'localhost'; //改成自己的mysql資料庫伺服器
$mysql_username = 'root'; //改成自己的mysql資料庫使用者名稱
$mysql_password = '123456'; //改成自己的mysql資料庫密碼
$mysql_database = 'test'; //改成自己的mysql資料庫名
$conn=mysqli_connect($mysql_server_name,$mysql_username,$mysql_password,$mysql_database); //連線資料庫
//連線資料庫錯誤提示
if (mysqli_connect_errno($conn)) {
die("連線 MySQL 失敗: " . mysqli_connect_error());
}
mysqli_query($conn,"set names utf8"); //資料庫編碼格式
//1、連線redis資料庫
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis_name = 'goods_id_2';//比如商品id=2的商品參與秒殺
//2、將list佇列中的資料讀取出來然後執行入庫
$redis_user_name = "goods_id_2_user_id";
while(true){
//判斷搶購列表中是否已存在該使用者,獲取列表中所有的資料
$result = $redis->rpop($redis_user_name);
if($result){
$skill_arr = array_filter(explode("_", $result));
$sql = "insert into skill (user_id,timestamp) values({$skill_arr[0]},{$skill_arr[1]})";
mysqli_query($conn,$sql); 
}
}
echo "執行成功";
登入後複製
f2c9cec116705a56a36769e125cb76c.jpg

以上就是簡單實現秒殺的場景,具體的程式碼還要根據實際的邏輯進行調整。

推薦學習:《》

以上就是php商城秒殺功能怎麼實現的詳細內容,更多請關注TW511.COM其它相關文章!