• 技术文章 >后端开发 >PHP问题

    php商城秒杀功能怎么实现

    藏色散人藏色散人2022-10-18 14:27:03原创300

    php商城秒杀功能的实现方法:1、打开php文件,连接redis数据库;2、创建待抢购商品的list列表;3、模拟用户请求并设置随机获取10名用户表示抢购成功;4、判断抢购列表中是否已存在该用户并获取列表中所有的数据;5、将redis中已抢购的用户保存到数据库中即可。

    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视频教程

    以上就是php商城秒杀功能怎么实现的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:php
    上一篇:php多重接口怎么实现 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• laravel高并发之抽奖秒杀解决方案• 分享php秒杀功能实现的思路• 浅谈使用nodejs设计一个秒杀系统的方法• 怎么解决PHP高并发(商品秒杀)问题?两种解决方案分享• 一起聊聊Redis实现秒杀的问题
    1/1

    PHP中文网