以购买商品举例:

① 从数据库获取库存的数量。

② 检查一下库存的数量是否充足。

③ 库存的数量减去买家购买的数量(以每个用户购买一个为例)。

④ 最后完成购买。

仅仅这几行逻辑代码在并发的情况下会出现问题,自己可以想象一下。

这里暂时就不测试了,下面会针对并发的处理给出测试结果。

创建表:

CREATE TABLE `warehouse` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id',
`stock` int(11) NOT NULL DEFAULT '0' COMMENT '库存',
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

第一种方案,使用Mysql的锁(跟表引擎没有关系)。

共享锁:所有人可以读一个资源,但只有获取锁的人可以操作;

排它锁:只有获得所的对象可以操作资源,其他的不能操作,读都不可以。

语法:

LOCK TABLE a READ,b WRITE,c READ,d WRITE;(可以锁多张表,在锁表的过程中只能操作被锁的表,不能操作其他表)。
UNLOCK TABLES;(释放表)。
@$mysql = mysql_connect('localhost','root','');
mysql_query('set names utf8');
mysql_select_db('test');
mysql_query('LOCK TABLE `warehouse` WRITE'); //锁表之后同一时间只有一个人能操作,也就是只有一个人能获取到锁
$sql = 'SELECT `stock` FROM warehouse';
$res = mysql_query($sql);
$row= mysql_fetch_array($res);
$stock = $row[0];
if( $stock < 1) {
die('库存不足');
}else{
$new_stock = intval($stock - 1);
mysql_query('UPDATE warehouse SET `stock` = '.$new_stock);
mysql_query('UPDATE TABLES');
}

锁表的缺点是:会出现阻塞,如果同时锁多张表的话,还会影响整个网站相关表的加载。

第二种方案,使用PHP的文件锁。

特点:当调用flock锁一个文件时,如果没有获取锁,直接返回FALSE,不会出现阻塞。

排它锁:flock($fp,LOCK_EX);

共享锁:flock($fp,LOCK_SH);

释放锁:flock($fp,LOCK_UN);

@$mysql = mysql_connect('localhost','root','');
mysql_query('set names utf8');
mysql_select_db('test');
$fp = fopen('./lock.txt','r');
$try = 10; //声明一个变量表示要获取的次数,防止死循环
do{
$lock = flock($fp, LOCK_EX);
if(!$lock)
usleep(5000); //如果没有获取到锁,释放CPU,休息5000毫秒
}while(!$lock && --$try >=0 );
if($lock) {
$sql = 'SELECT `stock` FROM warehouse';
$res = mysql_query($sql);
$row = mysql_fetch_array($res);
$stock = $row[0];
if( $stock < 1) {
die('库存不足');
}else{
$new_stock = intval($stock - 1);
mysql_query('UPDATE warehouse SET `stock` = '.$new_stock);
}
flock($fp, LOCK_UN);
fclose($fp); }else{ die('系统繁忙!'); }

第三种方案,简单的SQL语句就可以避免仓库为负数。

@$mysql = mysql_connect('localhost','root','');
mysql_query('set names utf8');
mysql_select_db('test');
mysql_query('UPDATE warehouse SET `stock` = `stock` -1 WHERE `stock` > 0'); //可以避免库存为负数

测试的方法是,找到Apache下的ab.exe,拖入CMD终端,然后输入指定参数测试。

具体参数说明Google一下你就知道,比如耗时之类的...这里不做详细说明。

PS:Mysql的表锁和PHP的文件锁在应对并发数量上也有差别,自己可以多测试。总之方案还有很多

Mysql的锁机制与PHP文件锁处理高并发简单思路的更多相关文章

  1. MySQL- 锁机制及MyISAM表锁

    锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源(如CPU.RAM.I/O等)的争用以外,数据也是一种供许 多用户 共享的资源.如何保证数据并发访问的一致性.有效性是所 ...

  2. mysql insert锁机制【转】

    最近再找一些MySQL锁表原因,整理出来一部分sql语句会锁表的,方便查阅,整理的不是很全,都是工作中碰到的,会持续更新 笔者能力有限,如果有不正确的,或者不到位的地方,还请大家指出来,方便你我,方便 ...

  3. 说一说MySQL的锁机制

    锁概述 MySQL的锁机制,就是数据库为了保证数据的一致性而设计的面对并发场景的一种规则. 最显著的特点是不同的存储引擎支持不同的锁机制,InnoDB支持行锁和表锁,MyISAM支持表锁. 表锁就是把 ...

  4. 关于MySQL的锁机制详解

    锁概述 MySQL的锁机制,就是数据库为了保证数据的一致性而设计的面对并发场景的一种规则. 最显著的特点是不同的存储引擎支持不同的锁机制,InnoDB支持行锁和表锁,MyISAM支持表锁. 表锁就是把 ...

  5. MySQL InnoDB锁机制

    概述: 锁机制在程序中是最常用的机制之一,当一个程序需要多线程并行访问同一资源时,为了避免一致性问题,通常采用锁机制来处理.在数据库的操作中也有相同的问题,当两个线程同时对一条数据进行操作,为了保证数 ...

  6. mysql的锁机制详解

    这段时间一直在学习mysql数据库.项目组一直用的是oracle,所以对mysql的了解也不深.本文主要是对mysql锁的总结. Mysql的锁主要分为3大类: 表级锁:存储引擎为Myisam.锁住整 ...

  7. mysql的锁机制,以及乐观锁,悲观锁,以及热点账户余额问题

    mysql的简单锁机制. myisam 1.只支持表级锁,所以经常更新的表结构不适宜用. 2.select也会产生锁表 innodb 1.支持事务,行级锁,表级锁,执行行级锁的前提是sql语句的索引有 ...

  8. MySQL:锁机制和隔离事务级别

    在mysql中的锁看起来是很复杂的,因为有一大堆的东西和名词:排它锁,共享锁,表锁,页锁,间隙锁,意向排它锁,意向共享锁,行锁,读锁,写锁,乐观锁,悲观锁,死锁.这些名词有的博客又直接写锁的英文的简写 ...

  9. MySQL 高级—— 锁机制

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.锁的概述 1.锁的定义 锁是计算机协调多个进程或线程并发访问某一资源的机制. 在数据库中,除传统的计 ...

随机推荐

  1. 转:Python之路,Day6 - 面向对象学习

    这篇文章写的不错,转来收了 转自:http://www.cnblogs.com/alex3714/articles/5188179.html   本节内容:   面向对象编程介绍 为什么要用面向对象进 ...

  2. MySQL服务器最大连接数怎么设置才合理[转]

    如果mysql 连接数据设置不合理可能会导致很小的流量mysql就提示MySQL: ERROR 1040: Too many connections错误了,那么要如何才算是合理设置mysql最大连接数 ...

  3. Intel DPDK 全面解读

    高性能网络技术 随着云计算产业的异军突起,网络技术的不断创新,越来越多的网络设备基础架构逐步向基于通用处理器平台的架构方向融合,从传统的物理网络到虚拟网络,从扁平化的网络结构到基于 SDN 分层的网络 ...

  4. Android 使用EventBus发送消息接收消息

    基本使用 自定义一个类 public class LoginEvent { private String code;//是否成功 public LoginEvent(String code) { th ...

  5. 在nagios中监控windows主机系统地址的状态

    原来的[root@nhserver2_5 objects]# cd /usr/local/nagios/etc/objects[root@nhserver2_5 objects]# vim comma ...

  6. sed&awk第二版读书笔记

    1. POSIX标准对正则表达式字符和操作符的含义进行了形式化.这种标准定义了两类正则表达式:基本的正则表达式(BRE),grep和sed使用这种正则表达式;扩展的表达式,egrep和awk使用这种正 ...

  7. 钉钉自定义机器人配合SVN钩子事件进行消息的推送实践

    目前很多公司还是使用SVN(TortoiseSVN)进行版本控制,使用简单,适合管理一般项目.协同办公软件目前钉钉比较成熟,阿里也一直在宣传推广,这两年公司也在使用,主要用于信息的沟通,其它的绩效.考 ...

  8. Java设计模式——观察者模式

    转载自:http://www.cnblogs.com/V1haoge/p/6513651.html 观察者接口:Observer public interface Observer { void up ...

  9. Es6 Symbol.iterator

    Symbol.iterator 为每一个对象定义了默认的迭代器.该迭代器可以被 for...of 循环结构使用. --描述 当需要迭代一个对象的时候(比如在 for...of 循环的开始时),它的 @ ...

  10. Hot Research Topics