• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL锁机制和PHP锁机制

MySQL锁机制和PHP锁机制

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了PHP, MYSQL, php文件锁, mysql锁 MySQL锁机制和PHP锁机制等相关知识,希望本文的分享对您有所帮助
模拟准备--如何模拟高并发访问一个脚本:apache安装文件的bin/ab.exe可以模拟并发量 -c 模拟多少并发量 -n 一共请求多少次 http://请求的脚本
例如:cmd: apache安装路径/bin/ab.exe -c 10 -n 10 http://web.test.com/test.php

【切入正题】
MYSQL中的锁:
语法 :
LOCK TABLE 表名1 READ|WRITE, 表名2 READ|WRITE .................. 【锁表】
UNLOCK TABLES 【释放表】


Read:读锁|共享锁 : 所有的客户端只能读这个表不能写这个表
Write:写锁|排它锁: 所有当前锁定客户端可以操作这个表,其他客户端只能阻塞
注意:在锁表的过程中只能操作被锁定的表,如果要操作其他表,必须把所有要操作的表都锁定起来!

PHP中的文件锁 (锁的是文件,不是表)
文件锁的文件与表有什么关系?:一点关系也没有,与令牌相似,谁拿到谁操作。所以表根本没锁。
测试时,有个文件就行,叫什么名无所谓

总结:
项目中应该只使用PHP中的文件锁,尽量避免锁表,因为如果表被锁定了,那么整个网站中所有和这个表相关的功能都被拖慢了(例如:前台很多用户一直下订单,商品表mysql锁表,其他与商品表相关的操作一直处于阻塞状态【读不出来商品表】,因为一个功能把整个网站速度拖慢)。

我的一个项目就是O2O外卖,中午12-2点,晚上6点都是订单高并发时,这种情况下,MySQL锁显然是不考虑的,用户体验太差。其实根据实际的需求,外卖可以不用设计库存量的,当然除了秒杀活动模块还是需要php文件锁的。

应用场景:
1. 高并发下单时,减库存量时要加锁
2. 高并发抢单、抢票时要使用

MySQL锁示例代码:

Php代码

<?php

/**

模拟秒杀活动-- 商品100件

CREATE TABLE a

(

id int comment '模拟100件活动商品的数量'

);

INSERT INTO a VALUES(100);

模仿:以10的并发量访问这个脚本! 使用apache自带的ab.exe软件

*/

error_reporting(0);

mysql_connect('localhost','root','admin123');

mysql_select_db('test');

# mysql 锁

mysql_query('LOCK TABLE a WRITE');// 只有一个客户端可以锁定表,其他客户端阻塞在这

$rs = mysql_query('SELECT id FROM a');

$id = mysql_result($rs, 0, 0);

if($id > 0)

{

--$id;

mysql_query('UPDATE a SET id='.$id);

}

# mysql 解锁

mysql_query('UNLOCK TABLES');


PHP文件锁示例代码:

Php代码

<?php

/**

模拟秒杀活动-- 商品100件

CREATE TABLE a

(

id int comment '模拟100件活动商品的数量'

);

INSERT INTO a VALUES(100);

模仿:以10的并发量访问这个脚本! 使用apache自带的ab.exe软件

*/

error_reporting(0);

mysql_connect('localhost','root','admin123');

mysql_select_db('test');

# php中的文件锁

$fp = fopen('./a.lock', 'r'); // php的文件锁和表没关系,随便一个文件即可

flock($fp, LOCK_EX);// 排他锁

$rs = mysql_query('SELECT id FROM a');

$id = mysql_result($rs, 0, 0);

if($id > 0)

{

--$id;

mysql_query('UPDATE a SET id='.$id);

}

# php的文件锁,释放锁

flock($fp, LOCK_UN);

fclose($fp);

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅析mysql 语句的调度优先级及改变
  • 基于mysql多实例安装的深入解析
  • mysql_fetch_row()与mysql_fetch_array()的使用介绍
  • 基于Php mysql存储过程的详解
  • PHP之Mysql常用SQL语句示例的深入分析
  • PHP mysqli 增强 批量执行sql 语句的实现代码
  • PHP mysqli扩展库 预处理技术的使用分析
  • Mysql中文乱码以及导出为sql语句和Excel问题解决方法[图文]
  • 修改mysql密码与忘记mysql密码的处理方法
  • 多次执行mysql_fetch_array()的指针归位问题探讨

相关文章

  • 2018-12-05MySQL 数据库跨操作系统的最快迁移方法
  • 2017-05-11replace MYSQL字符替换函数sql语句分享(正则判断)
  • 2018-12-05MySQL 事务实例教程
  • 2018-12-05Mysql结合备份+binlog恢复误删除操作数据
  • 2018-12-05SQL Server 作业的备份(备份作业非备份数据库)
  • 2018-12-05sql 查询本年、本月、本日记录的语句,附SQL日期函数
  • 2017-05-11远程连接mysql数据库注意点记录
  • 2018-12-05如何利用CMD连接本机mysql数据库
  • 2018-12-05MYSQL日志与备份还原详解
  • 2018-12-05mysql与oracle数据库停止与启动的批处理文件

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Centos5.5中安装Mysql5.5过程分享
    • MySQL 的日常使用
    • 具体介绍MAC下Mysql5.7.10版本修改root密码的方法
    • mysql 备份与迁移 数据同步方法
    • mssql 30万条数据 搜索文本字段的各种方式对比
    • mysql 控制台程序的提示符 prompt 字符串设置
    • 规范化的SQL数据修改语句总结
    • mysql 操作符
    • MYSQL建立外键失败几种情况记录Can't create table不能创建表
    • MySQL中InnoDB的Memcached插件的使用教程

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有