环境: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,'秒杀失败');
}
}
}
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼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]










