PHP 使用redis实现秒杀
PHP 使用redis实现秒杀
使用redis队列,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,推荐使用(mysql事务在高并发下性能下降很厉害,文件锁的方式也是)
先将商品库存如队列
- <?php
- $store=1000;
- $redis=new Redis();
- $result=$redis->connect('127.0.0.1',6379);
- $res=$redis->llen('goods_store');
- echo $res;
- $count=$store-$res;
- for($i=0;$i<$count;$i++){
- $redis->lpush('goods_store',1);
- }
- echo $redis->llen('goods_store');
- ?>
抢购、描述逻辑
- <?php
- $conn=mysql_connect("localhost","big","123456");
- if(!$conn){
- echo "connect failed";
- exit;
- }
- mysql_select_db("big",$conn);
- mysql_query("set names utf8");
- $price=10;
- $user_id=1;
- $goods_id=1;
- $sku_id=11;
- $number=1;
- //生成唯一订单号
- function build_order_no(){
- return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
- }
- //记录日志
- function insertLog($event,$type=0){
- global $conn;
- $sql="insert into ih_log(event,type)
- values('$event','$type')";
- mysql_query($sql,$conn);
- }
- //模拟下单操作
- //下单前判断redis队列库存量
- $redis=new Redis();
- $result=$redis->connect('127.0.0.1',6379);
- $count=$redis->lpop('goods_store');
- if(!$count){
- insertLog('error:no store redis');
- return;
- }
- //生成订单
- $order_sn=build_order_no();
- $sql="insert into ih_order(order_sn,user_id,goods_id,sku_id,price)
- values('$order_sn','$user_id','$goods_id','$sku_id','$price')";
- $order_rs=mysql_query($sql,$conn);
- //库存减少
- $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
- $store_rs=mysql_query($sql,$conn);
- if(mysql_affected_rows()){
- insertLog('库存减少成功');
- }else{
- insertLog('库存减少失败');
- }
- --
- -- 数据库: `big`
- --
- -- --------------------------------------------------------
- --
- -- 表的结构 `ih_goods`
- --
- CREATE TABLE IF NOT EXISTS `ih_goods` (
- `goods_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
- `cat_id` int(11) NOT NULL,
- `goods_name` varchar(255) NOT NULL,
- PRIMARY KEY (`goods_id`)
- ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ;
- --
- -- 转存表中的数据 `ih_goods`
- --
- INSERT INTO `ih_goods` (`goods_id`, `cat_id`, `goods_name`) VALUES
- (1, 0, '小米手机');
- -- --------------------------------------------------------
- --
- -- 表的结构 `ih_log`
- --
- CREATE TABLE IF NOT EXISTS `ih_log` (
- `id` int(11) NOT NULL AUTO_INCREMENT,
- `event` varchar(255) NOT NULL,
- `type` tinyint(4) NOT NULL DEFAULT '0',
- `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
- PRIMARY KEY (`id`)
- ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
- --
- -- 转存表中的数据 `ih_log`
- --
- -- --------------------------------------------------------
- --
- -- 表的结构 `ih_order`
- --
- CREATE TABLE IF NOT EXISTS `ih_order` (
- `id` int(11) NOT NULL AUTO_INCREMENT,
- `order_sn` char(32) NOT NULL,
- `user_id` int(11) NOT NULL,
- `status` int(11) NOT NULL DEFAULT '0',
- `goods_id` int(11) NOT NULL DEFAULT '0',
- `sku_id` int(11) NOT NULL DEFAULT '0',
- `price` float NOT NULL,
- `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='订单表' AUTO_INCREMENT=1 ;
- --
- -- 转存表中的数据 `ih_order`
- --
- -- --------------------------------------------------------
- --
- -- 表的结构 `ih_store`
- --
- CREATE TABLE IF NOT EXISTS `ih_store` (
- `id` int(11) NOT NULL AUTO_INCREMENT,
- `goods_id` int(11) NOT NULL,
- `sku_id` int(10) unsigned NOT NULL DEFAULT '0',
- `number` int(10) NOT NULL DEFAULT '0',
- `freez` int(11) NOT NULL DEFAULT '0' COMMENT '虚拟库存',
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='库存' AUTO_INCREMENT=2 ;
- --
- -- 转存表中的数据 `ih_store`
- --
- INSERT INTO `ih_store` (`id`, `goods_id`, `sku_id`, `number`, `freez`) VALUES
- (1, 1, 11, 500, 0);
PHP 使用redis实现秒杀的更多相关文章
- IDEA SpringBoot+JPA+MySql+Redis+RabbitMQ 秒杀系统
先放上github地址:spike-system,可以直接下载完整项目运行测试 SpringBoot+JPA+MySql+Redis+RabbitMQ 秒杀系统 技术栈:SpringBoot, MyS ...
- thinkphp+redis实现秒杀功能
好久没来整理文章了,闲了没事写篇文章记录下php+redis实现商城秒杀功能. 1,安装redis,根据自己的php版本安装对应的redis扩展(此步骤简单的描述一下) 1.1,安装 php_igbi ...
- .NetCore+Jexus代理+Redis模拟秒杀商品活动
开篇叙 本篇将和大家分享一下秒杀商品活动架构,采用的架构方案正如标题名称.NetCore+Jexus代理+Redis,由于精力有限所以这里只设计到商品添加,抢购,订单查询,处理队列抢购订单的功能:有不 ...
- 借助Redis做秒杀和限流的思考
最近群里聊起秒杀和限流,我自己没有做过类似应用,但是工作中遇到过更大的数据和并发. 于是提出了一个简单的模型: var count = rds.inc(key); if(count > 1000 ...
- thinkphp5使用redis实现秒杀商品活动
如题,废话少说贴码为上↓ // 初始化redis数据列表 模拟库存50,redis搭建在centos中已开启 public function redisinit(){ $store=50; // 库存 ...
- thinkphp5.0 - Redis 实现秒杀
首先,因为秒杀这个环节在商城项目中比较常见,最近写商城项目,碰到这个功能模块,于是就拿出来给大家分享一波. 难点:高并发的情况下,正常逻辑写的话数据库的库存会出现负数,对付这类问题有很多解决方案,我就 ...
- thinkphp+redis实现秒杀功能(转)
1,安装redis,根据自己的php版本安装对应的redis扩展(此步骤简单的描述一下) 1.1,安装 php_igbinary.dll,php_redis.dll扩展此处需要注意你的php版本如图: ...
- redis实现秒杀demo
代码 package com.prosay.redis; import java.util.List; import redis.clients.jedis.Jedis; import redis.c ...
- thinkphp+redis实现秒杀,缓存等功能
秒杀是商城常见功能 php+redis是最常见的秒杀功能 1,安装redis,根据自己的php版本安装对应的redis扩展 首先查看phpinfo();php环境信息 2,下载redis https ...
随机推荐
- [PGM] Bayes Network and Conditional Independence
2 - 1 - Semantics & Factorization 2 - 2 - Reasoning Patterns 2 - 3 - Flow of Probabilistic Influ ...
- eclipse中project facet问题
一般出现在从别处import的项目上,只有项目文件夹上有红叉,其他地方都正常,现总结个人的几个解决方案: 有几种可能: 1,编码设置是否一致,也即是你项目原来的编码和现在eclipse用的默认编码是否 ...
- 版本控制之一:SVN服务器搭建与安装(转)
Subversion是优秀的版本控制工具,其具体的的优点和详细介绍,这里就不再多说. 首先来下载和搭建SVN服务器. 现在Subversion已经迁移到apache网站上了,下载地址: http:// ...
- 针对数据量较大的表,需要进行跨库复制,采用navcat 实现sqlite数据库跨数据库的数据表迁移 [转载]
2014年12月13日 14:36 新浪博客 (转自http://www.cnblogs.com/nmj1986/archive/2012/09/17/2688827.html) 需求: 有两个不同的 ...
- Problem J: 求个最大值
Problem J: 求个最大值 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 871 Solved: 663[Submit][Status][Web ...
- thinkphp后台ajaxReturn提示下载的问题
thinkphp新版设置了ajaxreturn方法如果是JSON格式会自动设置头信息为JSON格式,这样做在谷歌下可以正常解析,但是在IE和OPERA浏览器下就会提示下载,从而导致程序出错,修改方法如 ...
- jQuery实现checkbox即点即改,批量计数,以及中间遇到的坑
最近要用jQuery实现一个批量删除操作,效果如下图 最终页面page.html,此页面使用了bootstrap和jQuery,如果没有需要下载一下 <!DOCTYPE html> < ...
- 一:Tomcat 服务器 在45秒内未启动成功
myeclipse或者eclipse中 tomcat 启动超时怎么办? 修改文件 找到Eclipse的工作空间\.metadata\.plugins\org.eclipse.wst.s ...
- WPF 完美截图 <序>
最近由于工作需要(话说总是工作需要哈),老大交给个任务,我鼓捣了2个星期,有点心得与大伙共享,希望对同被此问题困扰的同学有所帮助. 费话不说,上图: 此为完成后运行时状态图,先扔在这,下午有空开始正式 ...
- java之JVM学习--基本机构
JDK,JRE,JVM关系图 JVM物理结构: jvm内存区详解: 程序计数器 程序计数器(Program Counter Register)是一块较小的内存空间,它的作用可以看做是当前线程所执行的字 ...