环境:wamp,redis
要求:安装WAMP,Redis,以及为PHP安装Redis扩展
秒杀功能大致思路:获取缓存列表的长度,如果长度(llen)等于0,就停止秒杀,即秒杀失败,如果长度大于0,则继续运行,先从缓存中移除一个元素(lpop),再进行数据库操作(添加订单表,商品库存数量减一),如果再进一个人秒杀,就再走一遍流程,循环往复。
一、安装Redis扩展
1.查看PHP版本信息
打开phpinfo.php,查看PHP版本,我的是PHP7.3.4,还有一个需要注意Architecture x64
2.下载扩展文件
https://pecl.php.net/package/redis
https://pecl.php.net/package/igbinary
根据自己环境,选择合适的版本
3.解压
解压下载的压缩包,并把php_redis.dll、php_redis.pdb和php_igbinary.dll、php_igbinary.pdb四个文件,移至自己PHP版本对应目录下的ext文件夹下E:\phpstudy_pro\Extensions\php\php7.3.4nts\ext
4.修改php.ini
添加如下代码:
extension=php_igbinary.dll extension=php_redis.dll
如果有这两句可以把前面的分号删掉,没有就自己添加上,要注意顺序,php_igbinary.dll 要在php_redis.dll 前面
5.重启Apache
重启后,再运行phpinfo.php,查看是否安装成功
二、数据结构
一共三张表,ab_goods商品表,ab_order订单表,ab_log日志表
商品表
订单表
日志表 记录秒杀信息
三、代码
<"库存初始化完成:".$this->redis->llen($this->cachekey);
}
/**
* 秒杀入口
*/
public function index()
{
$id = 1; //商品编号
if (empty($id)) {
// 记录失败日志
return $this->writeLog(0,'商品编号不存在');
}
// 计算库存列表长度
$count = $this->redis->llen($this->cachekey);
// 先判断库存是否为0,为0秒杀失败,不为0,则进行先移除一个元素,再进行数据库操作
if ($count == 0) { //库存为0
$this->writeLog(0,'库存为0');
echo "库存为0";
exit;
}else{
// 有库存
//先移除一个列表元素
$this->redis->lpop($this->cachekey);
$ordersn = $this->build_order_no(); //生成订单
$uid = rand(0,9999); //随机生成用户id
$status = 1;
// 再进行数据库操作
$data = Db::table('ab_goods')->field('count,amount')->where('id',$id)->find(); //查找商品
if (!$data) {
return $this->writeLog(0,'该商品不存在');
}
$insert_data = [
'order_sn' => $ordersn,
'user_id' => $uid,
'goods_id' => $id,
'price' => $data['amount'],
'status' => $status,
'addtime' => date('Y-m-d H:i:s')
];
// 订单入库
$result = Db::table('ab_order')->insert($insert_data);
// 自动减少一个库存
$res = Db::table('ab_goods')->where('id',$id)->setDec('count');
if ($res) {
echo "第".$count."件秒杀成功";
$this->writeLog(1,'秒杀成功');
}else{
echo "第".$count."件秒杀失败";
$this->writeLog(0,'秒杀失败');
}
}
}
/**
* 生成订单号
*/
public function build_order_no()
{
return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
}
/**
* 生成日志 1成功 0失败
*/
public function writeLog($status = 1,$msg)
{
$data['count'] = 1;
$data['status'] = $status;
$data['addtime'] = date('Y-m-d H:i:s');
$data['msg'] = $msg;
return Db::table('ab_log')->insertGetId($data);
}
}
四、压力测试
使用apache压力测试工具 AB 测试,模拟多用户秒杀商品,模拟60秒内发起3000个请求,并发600次,秒杀50个库存商品
AB测试相关参数说明
- -r 指定接收到错误信息时不退出程序
- -t 等待响应的最大时间
- -n 指定压力测试总共的执行次数
- -c 用于指定压力测试的并发数
1.初始化50个库存,运行ms_init方法
2.测试 命令行:
E:\phpstudy_pro\Extensions\Apache2.4.39\bin>ab -r -t 60 -n 3000 -c 1000 http://gouwuche.zxf/index/miaosha/index
3.检测数据库数据
日志表状态为1(秒杀成功)的数据有50人,订单表里的订单数也是50条,商品表里的商品数量变成了0(测试之前是50),商品秒杀成功完成!
如果不用redis而是直接用mysql的话,商品表订单的数量count会变成负数,而秒杀成功的人数也多余50人,订单表里的订单数量也多余50条(新测),下面是直接用Mysql的例子;
public function sqlMs()
{
$id = 1; //商品编号
$count = 50;
$ordersn = $this->build_order_no(); //生成订单
$uid = rand(0,9999); //随机生成用户id
$status = 1;
// 再进行数据库操作
$data = Db::table('ab_goods')->field('count,amount')->where('id',$id)->find(); //查找商品
// 查询还剩多少库存
$rs = Db::table('ab_goods')->where('id',$id)->value('count');
if ($rs <= 0) {
$this->writeLog(0,'库存为0');
}else{
$insert_data = [
'order_sn' => $ordersn,
'user_id' => $uid,
'goods_id' => $id,
'price' => $data['amount'],
'status' => $status,
'addtime' => date('Y-m-d H:i:s')
];
// 订单入库
$result = Db::table('ab_order')->insert($insert_data);
// 自动减少一个库存
$res = Db::table('ab_goods')->where('id',$id)->setDec('count');
if ($res) {
echo "第".$data['count']."件秒杀成功";
$this->writeLog(1,'秒杀成功');
}else{
echo "第".$data['count']."件秒杀失败";
$this->writeLog(0,'秒杀失败');
}
}
}
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]










