PHP如何使用文件锁解决高并发问题

PHP如何使用文件锁解决高并发问题,第1张

<?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)

?>

方案一:使用文件锁排它锁

flock函数用于获取文件的锁,这个锁同时只能被一个线程获取到,其它没有获取到锁的线程要么阻塞,要么获取失败

在获取到锁的时候,先查询库存,如果库存大于0,则进行下订单 *** 作,减库存,然后释放锁

方案二:使用队列

将用户的下单请求依次存入一个队列中,后台用一个单独的进程处理队列中的下单请求

//WRITE

$fp = fopen("test.txt", 'ab') //From the end

flock($fp, LOCK_EX) //lock the file for waiting...

fwrite($fp, 'Just A Test String.......') //Start writing...

flock($fp, LOCK_UN) //Release write lock

fclose($fp) //Close the file读 *** 作:

//READ

$fp = fopen("test.txt", 'r')

flock($fp, LOCK_SH)

//Read from the file.......

flock($fp, LOCK_UN)

fclose($fp)来详细的看看 PHP 手册上面关于函数 flock 的介绍吧:

flock -- 轻便的咨询文件锁定

其函数原型为:bool flock ( int handle, int operation [, int &wouldblock] )

PHP 支持以咨询方式(也就是说所有访问程序必须使用同一方式锁定, 否则它不会工作)锁定全部文件的一种轻便方法,需要注意的地方是:在 Windows 下 flock() 将会强制执行。flock() *** 作的 handle 必须是一个已经打开的文件指针。operation 可以是以下值之一:

要取得共享锁定(读取的程序),将 operation 设为 LOCK_SH(PHP 4.0.1 以前的版本设置为 1)。

要取得独占锁定(写入的程序),将 operation 设为 LOCK_EX(PHP 4.0.1 以前的版本中设置为 2)。

要释放锁定(无论共享或独占),将 operation 设为 LOCK_UN(PHP 4.0.1 以前的版本中设置为 3)。

如果不希望 flock() 在锁定时堵塞,则给 operation 加上 LOCK_NB(PHP 4.0.1 以前的版本中设置为 4)。 flock() 允许执行一个简单的可以在任何平台中使用的读取/写入模型(包括大部分的 Unix 派生版和甚至是 Windows)。如果锁定会堵塞的话(EWOULDBLOCK 错误码情况下),可选的第三个参数会被设置为 TRUE。锁定 *** 作也可以被 fclose() 释放(代码执行完毕时也会自动调用)。如果成功则返回 TRUE,失败则返回 FALSE。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/8016663.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存