PHP 使用redis实现秒杀

使用redis队列,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,推荐使用(mysql事务在高并发下性能下降很厉害,文件锁的方式也是)

先将商品库存如队列

  1. <?php
  2. $store=1000;
  3. $redis=new Redis();
  4. $result=$redis->connect('127.0.0.1',6379);
  5. $res=$redis->llen('goods_store');
  6. echo $res;
  7. $count=$store-$res;
  8. for($i=0;$i<$count;$i++){
  9. $redis->lpush('goods_store',1);
  10. }
  11. echo $redis->llen('goods_store');
  12. ?>

抢购、描述逻辑

    1. <?php
    2. $conn=mysql_connect("localhost","big","123456");
    3. if(!$conn){
    4. echo "connect failed";
    5. exit;
    6. }
    7. mysql_select_db("big",$conn);
    8. mysql_query("set names utf8");
    9. $price=10;
    10. $user_id=1;
    11. $goods_id=1;
    12. $sku_id=11;
    13. $number=1;
    14. //生成唯一订单号
    15. function build_order_no(){
    16. return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    17. }
    18. //记录日志
    19. function insertLog($event,$type=0){
    20. global $conn;
    21. $sql="insert into ih_log(event,type)
    22. values('$event','$type')";
    23. mysql_query($sql,$conn);
    24. }
    25. //模拟下单操作
    26. //下单前判断redis队列库存量
    27. $redis=new Redis();
    28. $result=$redis->connect('127.0.0.1',6379);
    29. $count=$redis->lpop('goods_store');
    30. if(!$count){
    31. insertLog('error:no store redis');
    32. return;
    33. }
    34. //生成订单
    35. $order_sn=build_order_no();
    36. $sql="insert into ih_order(order_sn,user_id,goods_id,sku_id,price)
    37. values('$order_sn','$user_id','$goods_id','$sku_id','$price')";
    38. $order_rs=mysql_query($sql,$conn);
    39. //库存减少
    40. $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
    41. $store_rs=mysql_query($sql,$conn);
    42. if(mysql_affected_rows()){
    43. insertLog('库存减少成功');
    44. }else{
    45. insertLog('库存减少失败');
    46. }   
        1. --
        2. -- 数据库: `big`
        3. --
        4. -- --------------------------------------------------------
        5. --
        6. -- 表的结构 `ih_goods`
        7. --
        8. CREATE TABLE IF NOT EXISTS `ih_goods` (
        9. `goods_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
        10. `cat_id` int(11) NOT NULL,
        11. `goods_name` varchar(255) NOT NULL,
        12. PRIMARY KEY (`goods_id`)
        13. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ;
        14. --
        15. -- 转存表中的数据 `ih_goods`
        16. --
        17. INSERT INTO `ih_goods` (`goods_id`, `cat_id`, `goods_name`) VALUES
        18. (1, 0, '小米手机');
        19. -- --------------------------------------------------------
        20. --
        21. -- 表的结构 `ih_log`
        22. --
        23. CREATE TABLE IF NOT EXISTS `ih_log` (
        24. `id` int(11) NOT NULL AUTO_INCREMENT,
        25. `event` varchar(255) NOT NULL,
        26. `type` tinyint(4) NOT NULL DEFAULT '0',
        27. `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
        28. PRIMARY KEY (`id`)
        29. ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
        30. --
        31. -- 转存表中的数据 `ih_log`
        32. --
        33. -- --------------------------------------------------------
        34. --
        35. -- 表的结构 `ih_order`
        36. --
        37. CREATE TABLE IF NOT EXISTS `ih_order` (
        38. `id` int(11) NOT NULL AUTO_INCREMENT,
        39. `order_sn` char(32) NOT NULL,
        40. `user_id` int(11) NOT NULL,
        41. `status` int(11) NOT NULL DEFAULT '0',
        42. `goods_id` int(11) NOT NULL DEFAULT '0',
        43. `sku_id` int(11) NOT NULL DEFAULT '0',
        44. `price` float NOT NULL,
        45. `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
        46. PRIMARY KEY (`id`)
        47. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='订单表' AUTO_INCREMENT=1 ;
        48. --
        49. -- 转存表中的数据 `ih_order`
        50. --
        51. -- --------------------------------------------------------
        52. --
        53. -- 表的结构 `ih_store`
        54. --
        55. CREATE TABLE IF NOT EXISTS `ih_store` (
        56. `id` int(11) NOT NULL AUTO_INCREMENT,
        57. `goods_id` int(11) NOT NULL,
        58. `sku_id` int(10) unsigned NOT NULL DEFAULT '0',
        59. `number` int(10) NOT NULL DEFAULT '0',
        60. `freez` int(11) NOT NULL DEFAULT '0' COMMENT '虚拟库存',
        61. PRIMARY KEY (`id`)
        62. ) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COMMENT='库存' AUTO_INCREMENT=2 ;
        63. --
        64. -- 转存表中的数据 `ih_store`
        65. --
        66. INSERT INTO `ih_store` (`id`, `goods_id`, `sku_id`, `number`, `freez`) VALUES
        67. (1, 1, 11, 500, 0);

PHP 使用redis实现秒杀的更多相关文章

  1. IDEA SpringBoot+JPA+MySql+Redis+RabbitMQ 秒杀系统

    先放上github地址:spike-system,可以直接下载完整项目运行测试 SpringBoot+JPA+MySql+Redis+RabbitMQ 秒杀系统 技术栈:SpringBoot, MyS ...

  2. thinkphp+redis实现秒杀功能

    好久没来整理文章了,闲了没事写篇文章记录下php+redis实现商城秒杀功能. 1,安装redis,根据自己的php版本安装对应的redis扩展(此步骤简单的描述一下) 1.1,安装 php_igbi ...

  3. .NetCore+Jexus代理+Redis模拟秒杀商品活动

    开篇叙 本篇将和大家分享一下秒杀商品活动架构,采用的架构方案正如标题名称.NetCore+Jexus代理+Redis,由于精力有限所以这里只设计到商品添加,抢购,订单查询,处理队列抢购订单的功能:有不 ...

  4. 借助Redis做秒杀和限流的思考

    最近群里聊起秒杀和限流,我自己没有做过类似应用,但是工作中遇到过更大的数据和并发. 于是提出了一个简单的模型: var count = rds.inc(key); if(count > 1000 ...

  5. thinkphp5使用redis实现秒杀商品活动

    如题,废话少说贴码为上↓ // 初始化redis数据列表 模拟库存50,redis搭建在centos中已开启 public function redisinit(){ $store=50; // 库存 ...

  6. thinkphp5.0 - Redis 实现秒杀

    首先,因为秒杀这个环节在商城项目中比较常见,最近写商城项目,碰到这个功能模块,于是就拿出来给大家分享一波. 难点:高并发的情况下,正常逻辑写的话数据库的库存会出现负数,对付这类问题有很多解决方案,我就 ...

  7. thinkphp+redis实现秒杀功能(转)

    1,安装redis,根据自己的php版本安装对应的redis扩展(此步骤简单的描述一下) 1.1,安装 php_igbinary.dll,php_redis.dll扩展此处需要注意你的php版本如图: ...

  8. redis实现秒杀demo

    代码 package com.prosay.redis; import java.util.List; import redis.clients.jedis.Jedis; import redis.c ...

  9. thinkphp+redis实现秒杀,缓存等功能

    秒杀是商城常见功能  php+redis是最常见的秒杀功能 1,安装redis,根据自己的php版本安装对应的redis扩展 首先查看phpinfo();php环境信息 2,下载redis https ...

随机推荐

  1. du和df显示磁盘空间使用差异大的几种情况

     接触客户多了,发现经常有客户遇到du看到系统只使用了一部分磁盘空间,但df看时磁盘空间已经满了,或者差异较大,我遇到过三次不一样的原因,下面做一下总结,恶补一下!也希望对大家有点帮助! 现象:有客户 ...

  2. IIS 服务无法在此时接受控制信息

    应用程序池无法重新启动,报错:服务无法在此时接受控制信息 解决方法:重启 Credential Manager服务即可

  3. github和本地仓库关联

    1.安装git 2.在github上注册账号 3.github上创建repository 4.克隆github上的repository 5.在target directory中右键打开git gui

  4. 最长回文子串---Manacher算法

    百度:Manacher算法 代码 #include <iostream> #include <string> #include <cstring> #include ...

  5. Code Lock

    Code Lock Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Su ...

  6. css基础语法一(选择器与css导入方式)

    页面中,所有的CSS代码,需要写入到<style></style>标签中.style标签的type属性应该选择text/css,但是type属性可以省略. CSS修改页面中的所 ...

  7. 一键生成koa/koa2项目:

    一键生成koa/koa2项目: 1. npm install -g koa-generator 2.新建项目目录 koa mytest (koa1项目) koa2 koa2test (koa2项目) ...

  8. 使用spring框架中的组件发送邮件

    首先进入自己的QQ邮箱,在设置中修改账户信息 然后来至底部  点击开启,再用手机发送对应信息到指定号码,然后点击我已发送  获取授权码  注意提示: 到这里,相信你已经开通了SMTP服务,这样就可以在 ...

  9. [java基础] 遇到的一个关于返回值泛型的问题

    在写代码的时候这样写: import java.util.ArrayList; import java.util.List; public class TestConversion { public ...

  10. C++雾中风景1:友元类与面向对象

    因为后续准备入职的公司都希望能转C++,所以最近也是按部就班的开始进行C++的学习.然后这个系列的文章打算探究C++的语言特性,也比较一下不同语言(如Java,Scala,Python,Go)之间的设 ...