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. jvm - 垃圾回收

    jvm - 垃圾回收 注意 : 本系列文章为学习系列,部分内容会取自相关书籍或者网络资源,在文章中间和末尾处会有标注 垃圾回收的意义 它使得java程序员不再时时刻刻的关注内存管理方面的工作. 垃圾回 ...

  2. Angular通信$q服务和promise对象

    promise 约定(promise)是一个对象,表示在未来时间点会发生的某件事情,约定可以是三种状态之一:等待.完成或拒绝.约定将从等待状态开始,然后可以转换为完成或者拒绝状态,一旦约定完成或者被拒 ...

  3. ES6 for-of循环和迭代器使用细节

    SE5之前我们可以用for循环来遍历数组,SE5为数组引进了新的方法forEach(),方便了很多,但是该方法不能够通过break或者return返回外层函数. arr.forEach(functio ...

  4. 【转】java事件监听机制

    java中的事件机制的参与者有3种角色: 1.event object:事件状态对象,用于listener的相应的方法之中作为参数,一般存在与listerner的方法之中 2.event source ...

  5. continous integration environment (Jenkins and bitbucket configuration)

    ================================================================================ continous integrati ...

  6. POJ1222EXTENDED LIGHTS OUT(高斯消元)

    EXTENDED LIGHTS OUT Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 11815   Accepted: 7 ...

  7. 一条咸鱼的梦--python

    毕业到现在已经有一年多了,或者说已经工作了一年多,这样以一个社会人的说法比较贴切吧.工作的这段时间里,我曾经有无数次的在问我该干什么,我想干什么,这好像一个深奥的哲学问题,好像并不是只有我一个毕业生思 ...

  8. TestNG并行测试

    并行(多线程)技术在软件术语里被定义为软件.操作系统或者程序可以并行地执行另外一段程序中多个部分或者子组件的能力.TestNG允许我们以并行(多线程)的方式来执行测试.这就意味着基于TestNG测试组 ...

  9. 3.Apache ZooKeeper数据模型

    1. ZooKeeper自下向上的服务视图 Apache ZooKeeper是分布式应用程序的协调服务. 它旨在解决分布式应用程序中与组件协调相关的棘手问题. 它通过暴露一个简单而强大的接口来实现这一 ...

  10. Magicodes.Admin.Core开源框架总体介绍

    框架说明 Magicodes.Admin.Core框架在ABP以及ASP.NET ZERO的基础上进行了封装和完善,目前基于.NET Core 2.0+(Framework版本),由于部分组件在.NE ...