PHP使用文件锁解决高并发问题示例

PHP使用文件锁解决高并发问题示例

http://www.jb51.net/article/137359.htm

 

这篇文章主要介绍了PHP使用文件锁解决高并发问题,结合实例形式分析了php阻塞模式与非阻塞模式文件锁解决高并发的相关使用技巧,需要的朋友可以参考下

 

 

新建一个.txt文件,文件中什么都不用写。

【一】.阻塞(等待)模式:(只要有其他进程已经加锁文件,当前进程会一直等其他进程解锁文件)

 
<?php
//连接数据库
$con
=mysqli_connect(
"192.168.2.186"
,
"root"
,
"root"
,
"test"
);
//查询商品数量是否大于0,大于0才能下单,并减少库存
$fp
=
fopen
(
"lock.txt"
,
"r"
);
//加锁
if
(
flock
(
$fp
,LOCK_EX))
{
  
$res
=mysqli_fetch_assoc(mysqli_query(
$con
,
'SELECT total FROM shop WHERE id=1 LIMIT 1'
));
  
if
(
$res
[
'total'
]>0){mysqli_query(
$con
,
'UPDATE shop SET total=total-1 WHERE id=1'
);}
  
//执行完成解锁
  
flock
(
$fp
,LOCK_UN);
}
//关闭文件
fclose(
$fp
);
unset(
$res
);
mysqli_close(
$con
);
?>

 

【二】.非阻塞(等待)模式:(只要有其他进程已经加锁文件,当前进程不会等其他进程解锁文件直接返回)

 
<?php
//连接数据库
$con
=mysqli_connect(
"192.168.2.186"
,
"root"
,
"root"
,
"test"
);
//查询商品数量是否大于0,大于0才能下单,并减少库存
$fp
=
fopen
(
"lock.txt"
,
"r"
);
//加锁
if
(
flock
(
$fp
,LOCK_EX | LOCK_NB))
{
  
$res
=mysqli_fetch_assoc(mysqli_query(
$con
,
'SELECT total FROM shop WHERE id=1 LIMIT 1'
));
  
if
(
$res
[
'total'
]>0){mysqli_query(
$con
,
'UPDATE shop SET total=total-1 WHERE id=1'
);}
  
//执行完成解锁
  
flock
(
$fp
,LOCK_UN);
}
//关闭文件
fclose(
$fp
);
unset(
$res
);
mysqli_close(
$con
);
?>

如果连接数据库费时间的话,下面有个简单的小demo,可以更直观的理解下。

demo.php

 
<?php
$fp
=
fopen
(
"file_lock.txt"
,
"r"
);
// 加锁
if
(
flock
(
$fp
, LOCK_EX))
{
  
sleep(10);
  
echo
1;
  
//执行完成解锁
  
flock
(
$fp
,LOCK_UN);
}
else
{
  
echo
2;
}
//关闭文件
fclose(
$fp
);

demo2.php

 
<?php
$fp
=
fopen
(
"file_lock.txt"
,
"r"
);
// 加锁(如果改成flock($fp, LOCK_EX | LOCK_NB),demo2.php会直接返回2,否则会等待demo.php执行完返回1)
if
(
flock
(
$fp
, LOCK_EX))
{
  
echo
1;
}
else
{
  
echo
2;
}
//关闭文件
fclose(
$fp
);

同时运行两个文件,然后修改demo2中加锁机制,就可以看出来阻塞(等待)模式和非阻塞(等待)模式的区别了。

但是这样会导致队列堵塞,假如10个人同一秒写入数据库,那就堵塞了,第10个人会等待前9个都执行完才会执行!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113364.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Angularjs 服务

    Angularjs 服务AngularJS服务(Service):www.runoob.com/angularjs/angularjs-services.htmlAngularJS内建了30多个服务。官网搜索service吧https://docs.angularjs.org/api/ng/service/$window$http是AngularJS应用中最常用的服务。服务向服务器发送请求,应用响应服…

    2022年7月25日
    5
  • Linux运维常见面试题汇总

    Linux运维常见面试题汇总Linux面试题一、填空题1. 在Linux 系统中,以文件方式访问设备。2.Linux 内核引导时,从文件/etc/fstab中读取要加载的文件系统。3.Linux 文件系统中每个文件用indoe节点来标识。4. 全部磁盘块由四个部分组成,分别为引导块 、专用块 、 i 节点表块 和 数据存储块 。5. 链接分为:硬链接 和 符号链接 。

    2022年6月13日
    19
  • pyinstaller 多个.py打包exe_python怎么生成py文件

    pyinstaller 多个.py打包exe_python怎么生成py文件一、python安装pyinstaller方法使用python编写脚本,需要发给别人使用的时候,总会想到如何打包成exe文件,发给对方。这样的话,对方可以直接使用运行,无需安装python。所以看网上的教程,大多使用pyinstaller。以下介绍下安装方法:1、在cmd控制台下,先升级pip版本,先执行命:pipinstall-Upip,若执行失败,控制台会提示新密令,按照提示…

    2022年4月20日
    213
  • BoundsChecker

    BoundsChecker

    2021年8月12日
    58
  • pycharm最新激活码[最新免费获取]

    (pycharm最新激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~S32PGH0SQB-eyJsaWNlb…

    2022年3月26日
    51
  • 第九章第四节 流体压强与流速的关系「建议收藏」

    第九章第四节 流体压强与流速的关系「建议收藏」1.流速大的地方,压强小实例1:兵乓球实例2:如图,在离桌边2~3cm的地方放一枚铝制硬币,在硬币前10cm作用用直尺或钢笔等架起一个栏杆,高度约2cm。在硬币上方沿着与桌面平行的方向吹一口气

    2022年8月6日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号