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. 【JavaEE】企业面试问题-Java基础

    1. Java基础部分   1.1 Java中的方法覆盖(Overwrite)和方法重载(Overloading)是什么意思? 重载Overload表示同一个类中可以有多个名称相同的方法,但这些方法的 ...

  2. Shell中bash的特性小结

    Shell: 用户与操作系统之间完成交互式操作的一个接口程序,为用户提供简化了的操作:上世纪的70年代中期在贝尔实验室,Bourne位Unix开发了一个shell程序Bourne Shell,简称sh ...

  3. Muduo阅读笔记---入门(一)

    第一步:下载源码和文档 下载muduo项目的源码.<muduo-manual.pdf>文档,以及<Linux多线程服务端编程:使用muduo C++网络库.pdf>,这些是前期 ...

  4. IdentityServer4 通过 AccessToken 获取 UserClaims

    实现效果:通过生成的access_token获取用户的一些信息,这样客户端请求的时候,不需要传递用户信息了. 示例配置: public void ConfigureServices(IServiceC ...

  5. java爬虫--jsoup简单的表单抓取案例

    分析需求: 某农产品网站的农产品价格抓取 网站链接:点击打开链接 页面展示如上: 标签展示如上: 分析发现每日价格行情包括了蔬菜,水果,肉等所有的信息,所以直接抓每日行情的内容就可以实现抓取全部数据. ...

  6. JavaUtil_04_验证码生成器

    一.原理 验证码其实就是随机串.原理上可分为两种: 1.简单的验证码 直接通过字母和数字的ASCII码生成.本文采用的验证码就是这种. 2.复杂的验证码 通过一个随机串,一个指定串(如accesske ...

  7. 一个简单的MVC框架的实现-基于注解的实现

    1.@Action注解声明 package com.togogo.webtoservice.annotations; import java.lang.annotation.Documented; i ...

  8. 几种常用的ajax 跨域请求

      前 言 首先,我们要明白,什么是跨域,为什么要跨域. 由于JS中存在同源策略.当请求不同协议名不同端口号下面的文件时,将会违背同源策略,无法请求成功!需要进行跨域处理! 这篇文章就为大家详细介绍一 ...

  9. [Redis源码阅读]sds字符串实现

    初衷 从开始工作就开始使用Redis,也有一段时间了,但都只是停留在使用阶段,没有往更深的角度探索,每次想读源码都止步在阅读书籍上,因为看完书很快又忘了,这次逼自己先读代码.因为个人觉得写作需要阅读文 ...

  10. ASP.NET Core集成现有系统认证

    我们现在大多数转向ASP.NET Core来使用开发的团队,应该都不是从0开始搭建系统,而是老的业务系统已经在运行,ASP.NET Core用来开发新模块.那么解决用户认证的问题,成为我们的第一个拦路 ...