• TP5使用Redis处理电商秒杀


    本篇文章介绍了ThinkPHP使用Redis实现电商秒杀的处理方法,具有一定的参考价值,希望对学习ThinkPHP的朋友有帮助!

    TP5使用Redis处理电商秒杀

    1、首先在TP5中创建抢购活动所需要的Redis类库文件,代码如下:

    <php
    
        namespace appaseservice;
    
     
    
        use mikkle	p_redisRedisHashInfoBase;
    
      
    
        use thinkException;
    
      
    
        class ScheduleDetail extends RedisHashInfoBase
    
      
    
        {
    
      
    
            protected $table="gopar_schedule_detail"; //数据表的
    
      
    
            protected $pk = "id"; //数据表的主键
    
      
    
            public function _initialize()
    
      
    
            {
    
      
    
                //判断数据存在 并设置检查周期10分钟
    
      
    
                if (!$this->checkLock("dataExists") && !$this->checkTableDataExists()){
    
      
    
                    throw new Exception("相关产品数据不存在");
    
      
    
                }else{
    
      
    
                    //设置检查锁10分钟
    
      
    
                    $this->setLock("dataExists",600);
    
      
    
                }
    
      
    
                //如果数据不存在 初始化读取数据
    
      
    
                if (!$this->checkExists()){
    
      
    
                    $this->initTableData();
    
      
    
                }
    
      
    
            }
    
      
    
     
    
            public function getScheduleCenter()
    
      
    
            {
    
      
    
                return Schedule::instance( $this->getInfoFieldValue("schedule_id"));
    
      
    
            }
    
     
    
            public function __destruct()
    
      
    
            {
    
      
    
                //设置15天自动回收redis
    
      
    
                $this->setExpire((int);
    
      
    
    $this>getScheduleCenter()->getInfoFieldValue("end_time")+3600*24*15);
    
      
    
            }
    
      
    
        }
    

      

    2、在服务层或者控制器处理抢购逻辑,代码如下:

    public function index($data=["user_id"=>1,"ticket_detail_id"=>1,"buy_num"=>1]){
    
      
    
        try {
    
      
    
            //检测数据存在
    
      
    
            if (!$this->checkArrayValueEmpty($data,["user_id","ticket_detail_id","buy_num"])){
    
      
    
                throw new Exception($this->error);
    
      
    
            }
    
      
    
            $user_id= $data["user_id"] ; //用户Id
    
      
    
            $ticket_detail_id = $data["ticket_detail_id"] ; //产品Id
    
      
    
            $buy_num = $data["buy_num"] ; //购买数量
    
      
    
            $infoCenter= ScheduleDetail::instance( $ticket_detail_id );
    
      
    
            $scheduleDetailInfo =$infoCenter->getInfoList();
    
      
    
            //修改数据库后 需要运行initTableData()方法重新初始化 推荐写到Hook里
    
      
    
         // $infoCenter->initTableData();
    
      
    
            if ( $infoCenter->getInfoFieldValue( "hot_schedule")){
    
      
    
                //热门抢购随机过滤随机过滤
    
      
    
                if (!in_array(rand(100, 200) % 11, [1, 3, 5, 7, 9])) {
    
      
    
                    throw new Exception("抢票人数众多 ,你被挤出抢购队伍,还有余票,请重新再抢");
    
      
    
                };
    
      
    
            }
    
      
    
            // 这里判断 购买数量和销售日期 不符合就 throw new Exception
    
      
    
            if (!true){
    
      
    
                throw new Exception("这里写不符合原因");
    
      
    
            }
    
      
    
            if (((int)$infoCenter->getInfoFieldValue("{$user_id}_num")+$buy_num)>$scheduleDetailInfo["limit_num"] ){
    
      
    
                throw new Exception("你超过最大购买数量");
    
      
    
            }
    
      
    
            if ($infoCenter->setInfoFieldIncre("pay_num",$buy_num) >$scheduleDetailInfo["limit_num"] ){
    
      
    
                //
    
      
    
                $infoCenter->setInfoFieldIncre("pay_num", -$buy_num);
    
      
    
                throw new Exception("对不起,票已经卖光了!");
    
      
    
            }
    
      
    
            //这里写主逻辑 启用事务功能创建订单
    
      
    
            //事务参见下节源码
    
      
    
            //升级已销售数量
    
      
    
            $infoCenter->updateTableData(["pay_num"]);
    
      
    
            //在这里推荐埋钩子 处理订单完成的后续事情
    
      
    
             //返回结果
    
      
    
        } catch (Exception $e) {
    
      
    
            Log::error($e->getMessage());
    
      
    
            return ShowCode::jsonCodeWithoutData(1008, $e->getMessage());
    
      
    
        }
    
      
    
    }
    
      
    
    }
    

      

    在处理逻辑中 可以使用随机去除了一部分的购买请求 以保证抢购活动平稳完成

    当然也可以同时在前端请求中示例类似方法过滤

    可以参照定时队列判断订单是否处理完成 校准剩余库存

    推荐教程

    基础:

    手把手教你写留言板系统av78744637

    HTML+PHP+Mysql实现网站注册登录av78785761

    php从零教学支付技术大通关Av78773453

    零基础小白两小时入门PHP基础语法av81031138

    两小时熟练PHP基础语法八大数据类型av81050275

    PHP黄金搭档mysql数据库两小时基础入门av81142395

    PHP微信扫码支付从入门到实战av83815575

    PHP微信支付从入门到实战教程av83707632

    教你如何用laravel开发支付宝接口av77424057

    php扩展开发:

    PHP扩展开发——cookie与session原理实战av83825917

    php扩展开发——验证码开发av83864077

     

    tp:

    TP5开发大型ERP核心系统Auth认证组件av80969844

    女神老师讲解thinkphp6支付大通关av79763622

     

    redis:

    redis从入门到精通实战教程av83679805

    9年架构师教你用redis实现高并发限流av94478592

    9年架构师教你用redis实现高并发秒杀av94926372

    9年架构师讲解redis高并发秒杀解决方案av95010886

     

    swoole:

    PHP—swoole通往大神修炼之路:av77924246

    手把手教你用swoole+websocket实现户外监控直播(总集篇):av79087951

    教你用swoole开发网络游戏:av79264440

    PHP高级技术手写swoole分布式框架:av78383962

    PHP高级技术手写swoole分布式框架(二):av78632435

    PHP高级技术手写swoole分布式框架(三):av78748923

    PHP高级技术手写swoole分布式框架(框架优化):av78856427

    PHP高级技术手写swoole分布式框架(分布式RPC):av79012272

    用swoole实现消息推送:av79874641

    swoole+docker+redis主从复制及读写分离av78781841

    加薪、涨分利器-Swoole-Go协程+Mysql8.0实现高性能数据库连接池:av93991412

     

    更多学习内容请访问:

    怎么从一名码农成为架构师的必看知识点:目录大全(不定期更新)

  • 相关阅读:
    Linux监控平台、安装zabbix、修改zabbix的admin密码
    LVS DR模式搭建、keepalived+lvs
    负载均衡集群相关、LVS介绍、LVS调度算法、LVS NAT模式搭建
    集群相关、用keepalived配置高可用集群
    mysql基础
    MySQL主从、环境搭建、主从配制
    Tomcat配置虚拟主机、tomcat的日志
    Tomcat介绍、安装jdk、安装Tomcat、配置Tomcat监听80端口
    FTP相关、用vsftpd搭建ftp、xshell使用xftp传输文件、使用pure-ftpd搭建ftp服务
    HTTP Status 500
  • 原文地址:https://www.cnblogs.com/a609251438/p/12487478.html
Copyright © 2020-2023  润新知