我的编程空间,编程开发者的网络收藏夹
学习永远不晚

php商城秒杀功能怎么实现

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

php商城秒杀功能怎么实现

本教程操作环境: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商城秒杀功能怎么实现的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

php商城秒杀功能怎么实现

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么用Android实现京东秒杀功能

这篇“怎么用Android实现京东秒杀功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么用Android实现京东秒杀功能
2023-06-29

如何使用Redis实现秒杀功能

这篇文章主要介绍如何使用Redis实现秒杀功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1. 怎样预防数据库超售现象设置数据库事务的隔离级别为Serializable(不可用)Serializable就是让数据库
2023-06-14

thinkphp中怎么利用redis实现秒杀缓存功能

thinkphp中怎么利用redis实现秒杀缓存功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1,安装redis,根据自己的php版本安装对应的redis扩
2023-06-19

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录