首页 > 数据库 >TP5使用Redis处理电商秒杀-靳宇灵

TP5使用Redis处理电商秒杀-靳宇灵

时间:2022-12-03 18:00:41浏览次数:48  
标签:Exception 靳宇灵 Redis infoCenter throw num new 电商 id

TP5使用Redis处理电商秒杀

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

<php

namespace app\base\service;



use mikkle\tp_redis\RedisHashInfoBase;



use think\Exception;



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());



}



}

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

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

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

标签:Exception,靳宇灵,Redis,infoCenter,throw,num,new,电商,id
From: https://blog.51cto.com/u_15879708/5908619

相关文章

  • Redis面试问题
    问题一:Redis到底是单线程还是多线程?Redis6.0版本之前的单线程指的是其网络/O和键值对读写是由一个线程完成的Redis6.0引入的多线程指的是网络请求过程采用了多线程,而键值......
  • 二阶段:第8周 Redis缓存雪崩,穿透 没用
    list等于空直接set到redis缓存中   ......
  • [Redis] (三) 数据类型
    Redis数据类型Redis支持五种数据类型string(字符串)hash(哈希)list(列表)set(集合)zset(sortedset:有序集合)。String(字符串)string是redis最基本的类型,你可以理解成与......
  • K8S 部署电商项目
     Ingress和IngressController概述在k8s中为什么会有service这个概念?Pod漂移问题Kubernetes具有强大的副本控制能力,能保证在任意副本(Pod)挂掉时自动从其......
  • redis字符串的底层源码以及应用实例
    内部编码int8个字节的长整型embstr小于等于39个字节的字符串raw大于39个字节的字符串string底层使用的sds自定义的字符串,因为c语言中string默认为\0为结尾,而redi......
  • [Redis] (二) 配置
    Redis配置Redis的配置文件位于Redis安装目录下,文件名为redis.conf(Windows名为redis.windows.conf)。通过命令配置Redis可以通过CONFIG命令查看或设置配置项。......
  • [Redis] (一) 简介
    Redis是什么REmoteDIctionaryServer(Redis)是一个由SalvatoreSanfilippo写的key-value存储系统,是跨平台的非关系型数据库。Redis是一个开源的使用ANSIC语言......
  • 杨建允:抖快直播电商的运营逻辑是否可以复制
      定位:找准自己的细分领域,专注、专业 从2021年开始,各大平台从流量经营、效率经营,逐渐回归到用户心智的经营,根据特劳斯的“定位”理论,用户每个领域的心智资源都是有限的......
  • 基于redis的点赞功能
    初始代码@GetMapping("/likes/{id}")publicResultqueryBlogLikes(@PathVariable("id")Longid){//修改点赞数量blogService.update().setSql("liked=li......
  • 阶段一:单体电商项目架构,开发与上线(1~5周)
          模块间依赖    数据库建模用pdman            前后端跨域问题的配置 ......