TP5使用Redis处理电商秒杀
本篇文章介绍了ThinkPHP使用Redis实现电商秒杀的处理方法,具有一定的参考价值,希望对学习ThinkPHP的朋友有帮助!
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());
}
}
}
在处理逻辑中 可以使用随机去除了一部分的购买请求 以保证抢购活动平稳完成
当然也可以同时在前端请求中示例类似方法过滤
可以参照定时队列判断订单是否处理完成 校准剩余库存
推荐教程
基础:
手把手教你写留言板系统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
更多学习内容请访问:
怎么从一名码农成为架构师的必看知识点:目录大全(不定期更新)
TP5使用Redis处理电商秒杀的更多相关文章
- php+redis实现电商秒杀功能
这一次总结和分享用Redis实现分布式锁来完成电商的秒杀功能.先扯点个人观点,之前我看了一篇博文说博客园的文章大部分都是分享代码,博文里强调说分享思路比分享代码更重要(貌似大概是这个意思,若有误请谅解 ...
- 使用Redis搭建电商秒杀系统
背景 秒杀活动是绝大部分电商选择的低价促销.推广品牌的方式.不仅可以给平台带来用户量,还可以提高平台知名度.一个好的秒杀系统,可以提高平台系统的稳定性和公平性,获得更好的用户体验,提升平台的口碑,从而 ...
- Web系统大规模并发——电商秒杀与抢购
电商的秒杀和抢购,对我们来说,都不是一个陌生的东西.然而,从技术的角度来说,这对于Web系统是一个巨大的考验.当一个Web系统,在一秒钟内收到数以万计甚至更多请求时,系统的优化和稳定至关重要.这次我们 ...
- Web系统大规模并发——电商秒杀与抢购 【转】
电商的秒杀和抢购,对我们来说,都不是一个陌生的东西.然而,从技术的角度来说,这对于Web系统是一个巨大的考验.当一个Web系统,在一秒钟内收到数以万计甚至更多请求时,系统的优化和稳定至关重要.这次我们 ...
- 徐汉彬:Web系统大规模并发——电商秒杀与抢购(转)
[导读]徐汉彬曾在阿里巴巴和腾讯从事4年多的技术研发工作,负责过日请求量过亿的Web系统升级与重构,目前在小满科技创业,从事SaaS服务技术建设. 电商的秒杀和抢购,对我们来说,都不是一个陌生的东西. ...
- 【问底】徐汉彬:Web系统大规模并发——电商秒杀与抢购
[导读]徐汉彬曾在阿里巴巴和腾讯从事4年多的技术研发工作,负责过日请求量过亿的Web系统升级与重构,目前在小满科技创业,从事SaaS服务技术建设. 电商的秒杀和抢购,对我们来说,都不是一个陌生的东西. ...
- 徐汉彬:Web系统大规模并发——电商秒杀与抢购
[导读]徐汉彬曾在阿里巴巴和腾讯从事4年多的技术研发工作,负责过日请求量过亿的Web系统升级与重构,目前在小满科技创业,从事SaaS服务技术建设. 电商的秒杀和抢购,对我们来说,都不是一个陌生的东西. ...
- 从电商秒杀与抢购谈Web系统大规模并发
从电商秒杀与抢购谈Web系统大规模并发 http://www.iamlintao.com/4242.html 一.大规模并发带来的挑战 在过去的工作中,我曾经面对过5w每秒的高并发秒杀功能,在这个过程 ...
- Web系统大规模并发:电商秒杀与抢购-----面试必问
一.大规模并发带来的挑战 在过去的工作中,我曾经面对过5w每秒的高并发秒杀功能,在这个过程中,整个Web系统遇到了很多的问题和挑战.如果Web系统不做针对性的优化,会轻而易举地陷入到异常状态.我们现在 ...
随机推荐
- WebService如何根据WSDL文件转换成本地的C#类
WebService有两种使用方式,一种是直接通过添加服务引用,另一种则是通过WSDL生成. 添加服务引用大家基本都用过,这里就不讲解了. 那么,既然有直接引用的方式,为什么还要通过WSDL生成呢? ...
- 关于AI行业创业的6个问题
第一个问题:互联网 vs 人工智能 首先如果今天大家选择创业,我建议更应该关注人工智能,而非互联网.为什么这么讲? 1. 互联网的流量红利已经消失: 以PC来说,全球PC出货量连续5年下滑.大家知道国 ...
- iOS天气动画、高仿QQ菜单、放京东APP、高仿微信、推送消息等源码
iOS精选源码 TYCyclePagerView iOS上的一个无限循环轮播图组件 iOS高仿微信完整项目源码 想要更简单的推送消息,看本文就对了 ScrollView嵌套ScrolloView解决方 ...
- eclipse 大括号改为C语言一样的代码块
如图:找到Windows->Preferences->Java->Code Style->Formatter: 然后,点击右边的Edit按钮: 按如下图完成
- hibernate主键(generator)生成方式
1) assigned 主键由外部程序负责生成,无需Hibernate参与. 2) hilo 通过hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态. 3) seqhilo 与 ...
- <JZOJ5943>树
一开始t了五个点我就一脸懵逼 然后 发现高级操作... 就是那个tor的数组2333 可以让一些不需要改的不再去改啦 位运算果然是神奇的东西XD 魔性哈哈哈 #include<cstdio> ...
- byte的取值范围是-128~127,那么包含-128和127吗?
本帖最后由 王德升老师 于 2019-12-27 17:56 编辑 byte的取值范围为什么是-128~127?如果面试官问你取值范围包含127吗?1. 首先我们知道Java中byte类型是1个字节占 ...
- fastdfs+nginx make时报错fatal error:fdfs_define.h: 没有那个文件或目录
环境: ubuntu 18.04.1 fastdfs-nginx-module_v1.16 root@wang-machine:~/桌面/FastDFS# cd nginx-1.8.1/root@wa ...
- linux系统加固方案
Linux主机操作系统加固规范 目 录 第1章 概述... 1 1.1 目的... 1 1.2 适用范围... 1 1.3 适用版本... 1 1 ...
- ES6学习总结(五)
与其说是对象合并,还不如说是JavaScript中对象属性的复制和转移,将多个对象中的属性合并到一个对象中 12345678 var person = { name : 'John', age : 2 ...