高并发下用pdo,文件排它锁,redis三种方法对比
<?phpheader('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三种方法对比的更多相关文章
- linux清空文件内容的三种方法
linux系统中清空文件内容的三种方法 1.使用vi/vim命令打开文件后,输入"%d"清空,后保存即可.但当文件内容较大时,处理较慢,命令如下:vim file_name:%d: ...
- 详解linux下批量替换文件内容的三种方法(perl,sed,shell)
在建设本网站的时候,发现新建了很多的网页,突然发现,每个文件都需要进行修改一样的内容,一个一个打开很是麻烦,所以,总结了一下如何快速修改一个目录下多个文件进行内容替换.第三种方法用的不多 方法一 使用 ...
- php读取文件内容的三种方法
<?php //**************第一种读取方式***************************** 代码如下: header("content-type:text/h ...
- Delphi中实现文件拷贝的三种方法
1.调用API函数procedure CopyFile(FromFileName,ToFileName:string);varf1,f2:file;BeginAssignFile(f1,FromFil ...
- Java追加文件内容的三种方法
import java.io.BufferedWriter; import java.io.File; import java.io.FileOutputStream; import java.io. ...
- ASP.net 判断上传文件类型的三种方法
一. 安全性比较低,把文本文件1.txt改成1.jpg照样可以上传,但其实现方法容易理解,实现也简单,所以网上很多还是采取这种方法. Boolean fileOk = false; string pa ...
- 用ASP.net判断上传文件类型的三种方法
一. 安全性比较低,把文本文件1.txt改成1.jpg照样可以上传,但其实现方法容易理解,实现也简单,所以网上很多还是采取这种方法. Boolean fileOk = false; ...
- 前端下载excel文件功能的三种方法
1 从后端接收json数据,前端处理生成excel下载 JsonExportExcel的github地址:https://github.com/cuikangjie/JsonExportExcel 这 ...
- [原]Linux下清空文件内容的三种方法
========问题======== 有些文件需要清空内容而不改变属性 =======解决方案====== 1.直接删除,创建同名文件.(这种方法的弊端是有可能这个文件带着权限或者是属性,那么你新建这 ...
随机推荐
- 《TomCat与Java Web开发技术详解》(第二版) 第八章节的学习总结 -- 访问mysql
终于学到如何访问Mysql了 1. 可以看看此章节提供的sql脚本,以后可以照着写了.此外,对于Mysql如何使用,最好的地方就是其官网介绍了.http://dev.mysql.com/doc/ref ...
- 解决Apache长时间占用内存大的问题,Apache 内存优化方法
问:为什么服务器在连续运行多天后或访问峰值后,进程中的一个Apache.exe占用内存几百兆不减少?答:用记事本打开apache2\conf\httpd.conf,我在centos5上装了kloxo, ...
- 检测session用户信息跳转首页界面
方案一:采用jsp方式检测用户信息跳转 <%@ page language="java" pageEncoding="UTF-8"%> <%@ ...
- Java学习笔记之equals和Objects.equals
equals 相信大家就知道,就是比较,我们平时也会在自己定义的类中加入自己重写的equals用来比较两个类是否相同,例如这样 public class Person { private String ...
- IOS下移除按钮默认美化样式
今天在做项目中发现 ios会自己美化按钮的样式 美化的一般都是加一个圆角 也就是常说的border-radius 属性 今天在弄一个input标签的时候加了一个border-bottom属性 ...
- 【BZOJ3991】[SDOI2015]寻宝游戏 树链的并+set
[BZOJ3991][SDOI2015]寻宝游戏 Description 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩 ...
- Apache Maven pom文件
Welcome to Apache Maven Apache Maven is a software project management and comprehension tool. Based ...
- PAT 组合数的和(15)
给定N个非0的个位数字,用其中任意2个数字都可以组合成1个2位的数字.要求所有可能组合出来的2位数字的和.例如给定2.5.8,则可以组合出:25.28.52.58.82.85,它们的和为330. 输入 ...
- Android N API预览
Android N for Developers 重要的开发人员功能 多窗体支持 通知 JIT/AOT 编译 高速的应用安装路径 外出瞌睡模式 后台优化 Data Saver 高速设置图块 API 号 ...
- Android异步载入全解析之使用AsyncTask
Android异步载入全解析之使用AsyncTask 概述 既然前面提到了多线程,就不得不提到线程池,通过线程池,不仅能够对并发线程进行管理.更能够提高他们运行的效率.优化整个App.当然我们能够自己 ...