//连接数据库
$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。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)