tp5分布式redis_TP5使用Redis处理电商秒杀

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

tp5使用redis处理电商秒杀

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

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

}

}

}

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

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

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

推荐教程

基础:

手把手教你写留言板系统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

更多学习内容请访问:

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值