<?php
header('content-type:text/html;charset=utf-8');
 
         
    // //无控制
    // $DB_DSN = 'mysql:dbname=blog;host=127.0.0.1';
    // $DB_USER = 'root';
    // $DB_PWD = 'root';
     
    // $pdo = new PDO($DB_DSN, $DB_USER, $DB_PWD);
    // $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // 设置数据库连接为持久连接
    // $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 设置抛出错误
    // $pdo->setAttribute(PDO::ATTR_ORACLE_NULLS, true); // 设置当字符串为空转换为 SQL 的 NULL
    // $pdo->query('SET NAMES utf8'); // 设置数据库编码
         
    // function build_order_no() { //生成唯一订单
    //   return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    // }
     
    // $price=10;
    // $user_id=1;
    // $goods_id=1;
    // $sku_id=11;
    // $number=1;
     
    // //模拟下单操作
    // //库存是否大于0
    // //解锁 此时ih_store数据中goods_id='$goods_id' and sku_id='$sku_id' 的数据被锁住(注3),其它事务必须等待此次事务 提交后才能执行
    // $sql = "select number from ih_store where goods_id='$goods_id' and sku_id='$sku_id'";
    // $rs = $pdo->query($sql);
    // $row = $rs->FetchColumn();
    // if($row > 0){ //高并发下会导致超卖
    //  $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 = $pdo->query($sql);
          
    // // var_dump($order_rs);die;
    //  //库存减少
    //  $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
    //  $store_rs = $pdo->query($sql);
         
    // //   if($store_rs->rowCount()) {
    // //       error_log('订单号:'.$order_sn.'库存减少成功<br>');
    // //   } else {
    // //       error_log('订单号:'.$order_sn.'库存减少失败<br>');
    // //   }
 
    // // }else{
    // //   //error_log('库存不够<br>');
    // }
     
     
     
     
    // //开启事物
    // $DB_DSN = 'mysql:dbname=blog;host=127.0.0.1';
    // $DB_USER = 'root';
    // $DB_PWD = 'root';
     
    // $pdo = new PDO($DB_DSN, $DB_USER, $DB_PWD);
    // $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // 设置数据库连接为持久连接
    // $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 设置抛出错误
    // $pdo->setAttribute(PDO::ATTR_ORACLE_NULLS, true); // 设置当字符串为空转换为 SQL 的 NULL
    // $pdo->query('SET NAMES utf8'); // 设置数据库编码
         
    // function build_order_no() { //生成唯一订单
    //   return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    // }
     
    // $price=10;
    // $user_id=1;
    // $goods_id=1;
    // $sku_id=11;
    // $number=1;
     
    // //模拟下单操作
    // //库存是否大于0
    // //解锁 此时ih_store数据中goods_id='$goods_id' and sku_id='$sku_id' 的数据被锁住(注3),其它事务必须等待此次事务 提交后才能执行
 
    // $pdo->query('BEGIN');
 
    // $sql = "select number from ih_store where goods_id='$goods_id' and sku_id='$sku_id'";
    // $rs = $pdo->query($sql);
    // $row = $rs->FetchColumn();
    // if($row > 0){ //高并发下会导致超卖
    //  $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 = $pdo->query($sql);
          
    //  //库存减少
    //  $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
    //  $store_rs = $pdo->query($sql);
         
    //  // if($store_rs->rowCount()) {
    //  //  error_log('订单号:'.$order_sn.'库存减少成功<br>');
    //      $pdo->query('COMMIT');
    //  // } else {
    //  //  error_log('订单号:'.$order_sn.'库存减少失败<br>');
    //  // }
 
    // // var_dump($order_rs);die;
    // }else{
    //  //error_log('库存不够<br>');
    //  $pdo->query('ROLLBACK');
         
    // }
     
     
     
 
     
    // //使用非阻塞的文件排他锁
    // $DB_DSN = 'mysql:dbname=blog;host=127.0.0.1';
    // $DB_USER = 'root';
    // $DB_PWD = 'root';
     
    // $pdo = new PDO($DB_DSN, $DB_USER, $DB_PWD);
    // $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // 设置数据库连接为持久连接
    // $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 设置抛出错误
    // $pdo->setAttribute(PDO::ATTR_ORACLE_NULLS, true); // 设置当字符串为空转换为 SQL 的 NULL
    // $pdo->query('SET NAMES utf8'); // 设置数据库编码
         
    // function build_order_no() { //生成唯一订单
    //   return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    // }
     
    // $price=10;
    // $user_id=1;
    // $goods_id=1;
    // $sku_id=11;
    // $number=1;
     
    // //模拟下单操作
    // //库存是否大于0
 
    // $fp = fopen("lock.txt", "w+");
    // if(!flock($fp,LOCK_EX | LOCK_NB)){
    //  echo "系统繁忙,请稍后再试";
    //  return;
    // }
 
    // $sql = "select number from ih_store where goods_id='$goods_id' and sku_id='$sku_id'";
    // $rs = $pdo->query($sql);
    // $row = $rs->FetchColumn();
     
    // if($row > 0){ //高并发下会导致超卖
    //  $order_sn = build_order_no();
         
     
          
    //  //库存减少
    //  $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
    //  $store_rs = $pdo->query($sql);
         
    //  if($store_rs->rowCount()) {
 
    //          //生成订单
    //  $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 = $pdo->query($sql);
    //      error_log('订单号:'.$order_sn.'库存减少成功<br>');
    //  } else {
    //      error_log('订单号:'.$order_sn.'库存减少失败<br>');
    //  }
    //  flock($fp,LOCK_UN);//释放锁
    // }else{
    //  error_log('库存不够<br>');
    // }
    // fclose($fp);
     
         
     
     
    //队列
     
     
    $store = 500;
    $redis = new Redis();
    $result = $redis->connect('127.0.0.1', 6379);
    $redis->FLUSHALL();
 
    $res = $redis->llen('goods_store');
     
    $count = $store-$res;
    for($i=1;$i<=$count;$i++){
        $redis->lpush('goods_store', $i);
    }
    echo $redis->llen('goods_store');
    exit;
     
     
 
     
     
 
 
    $DB_DSN = 'mysql:dbname=blog;host=127.0.0.1';
    $DB_USER = 'root';
    $DB_PWD = 'root';
     
    $pdo = new PDO($DB_DSN, $DB_USER, $DB_PWD);
    $pdo->setAttribute(PDO::ATTR_PERSISTENT, true); // 设置数据库连接为持久连接
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 设置抛出错误
    $pdo->setAttribute(PDO::ATTR_ORACLE_NULLS, true); // 设置当字符串为空转换为 SQL 的 NULL
    $pdo->query('SET NAMES utf8'); // 设置数据库编码
     
    function build_order_no() { //生成唯一订单
        $sn = microtime().''.rand(10000,100000).''.microtime().''.rand(10000,100000);
        return $sn;
      //return date('ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    }
     
    $price=10;
    $user_id=1;
    $goods_id=1;
    $sku_id=11;
    $number=1;
     
    //模拟下单操作
    $redis=new Redis();
    $result=$redis->connect('127.0.0.1', 6379);
    $count = $redis->rpop('goods_store');
     
    if(!$count){
        error_log('队列'.$count.'redis:库存不足');
    } else {
 
        $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 = $pdo->query($sql);
              
        //库存减少
        $sql="update ih_store set number=number-{$number} where sku_id='$sku_id'";
        $store_rs = $pdo->query($sql);
         
        if($store_rs->rowCount()) {
            error_log('队列:'.$count.'订单号:'.$order_sn.'库存减少成功<br>');
        } else {
            error_log('队列:'.$count.'订单号:'.$order_sn.'库存减少失败<br>');
        }
    }
    

自我感觉,文件排它锁比较慢,pdo处理高并发效果一般,redis是最有效的

高并发下用pdo,文件排它锁,redis三种方法对比的更多相关文章

  1. linux清空文件内容的三种方法

    linux系统中清空文件内容的三种方法 1.使用vi/vim命令打开文件后,输入"%d"清空,后保存即可.但当文件内容较大时,处理较慢,命令如下:vim file_name:%d: ...

  2. 详解linux下批量替换文件内容的三种方法(perl,sed,shell)

    在建设本网站的时候,发现新建了很多的网页,突然发现,每个文件都需要进行修改一样的内容,一个一个打开很是麻烦,所以,总结了一下如何快速修改一个目录下多个文件进行内容替换.第三种方法用的不多 方法一 使用 ...

  3. php读取文件内容的三种方法

    <?php //**************第一种读取方式***************************** 代码如下: header("content-type:text/h ...

  4. Delphi中实现文件拷贝的三种方法

    1.调用API函数procedure CopyFile(FromFileName,ToFileName:string);varf1,f2:file;BeginAssignFile(f1,FromFil ...

  5. Java追加文件内容的三种方法

    import java.io.BufferedWriter; import java.io.File; import java.io.FileOutputStream; import java.io. ...

  6. ASP.net 判断上传文件类型的三种方法

    一. 安全性比较低,把文本文件1.txt改成1.jpg照样可以上传,但其实现方法容易理解,实现也简单,所以网上很多还是采取这种方法. Boolean fileOk = false; string pa ...

  7. 用ASP.net判断上传文件类型的三种方法

    一. 安全性比较低,把文本文件1.txt改成1.jpg照样可以上传,但其实现方法容易理解,实现也简单,所以网上很多还是采取这种方法. Boolean fileOk = false;           ...

  8. 前端下载excel文件功能的三种方法

    1 从后端接收json数据,前端处理生成excel下载 JsonExportExcel的github地址:https://github.com/cuikangjie/JsonExportExcel 这 ...

  9. [原]Linux下清空文件内容的三种方法

    ========问题======== 有些文件需要清空内容而不改变属性 =======解决方案====== 1.直接删除,创建同名文件.(这种方法的弊端是有可能这个文件带着权限或者是属性,那么你新建这 ...

随机推荐

  1. 《TomCat与Java Web开发技术详解》(第二版) 第六章节的学习总结 ---- JSP技术

    第六章主要介绍了JSP的相关知识. 1.JSP:是通过在HTML文件中加入java程序片段(Java Scriptlet)和JSP标记,就构成了JSP文件.JSP实质上是Servlet.JSP的API ...

  2. Oracle PL/SQL 高级编程

    1. 复合数据类型--记录类型 Ø        语法格式 type  类型名 is   record ( 字段1  字段1类型 [not null]:=表达式1; 字段2  字段2类型 [not n ...

  3. C语言进行站点开发之cgi

     安装Apach 配置ApacheRuntime 以下的过程中一直点击next 配置CGI,放开配置:AddHandler cgi-script .cgi watermark/2/text/aHR ...

  4. 3354 [IOI2005]河流

    题目描述 几乎整个Byteland王国都被森林和河流所覆盖.小点的河汇聚到一起,形成了稍大点的河.就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海.这条大河的入海口处有一个村庄——名叫 ...

  5. WCF基础之Message类

    客户端和服务端的通信都是通过接收和发送的Message实例建立起来的,大多数情况我们通过服务协定.数据协定和消息协定来构造传入和传出消息的. 一般什么时候使用Message类呢?不需要将消息序列化或者 ...

  6. 九度OJ 1355:扑克牌顺子 (模拟)

    时间限制:2 秒 内存限制:32 兆 特殊判题:否 提交:1676 解决:484 题目描述: LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^). ...

  7. Python菜鸟之路:Python基础-线程池注释

    import sys import threading import Queue import traceback # 定义一些Exception,用于自定义异常处理 class NoResultsP ...

  8. Vue学习-基础语法

    Vue v-if指令 Vue.js的指令是以v-开头的,它们作用于HTML元素,指令提供了一些特殊的特性,将指令绑定在元素上时,指令会为绑定的目标元素添加一些特殊的行为,我们可以将指令看作特殊的HTM ...

  9. python利用wxpy监控微信公众号

    此次利用wxpy可以进行微信公众号的消息推送监测(代码超级简单),这样能进行实时获取链接.但是不光会抓到公众号的消息,好友的消息也会抓到(以后会完善的,毕竟现在能用了,而且做项目的微信号肯定是没有好友 ...

  10. 【整理学习Hadoop】Hadoop学习基础之一:服务器集群技术

            服务器集群就是指将很多服务器集中起来一起进行同一种服务,在客户端看来就像是只有一个服务器.集群可以利用多个计算机进行并行计算从而获得很高的计算速度,也可以用多个计算机做备份,从而使得任 ...