新建一个.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个都执行完才会执行!
以上就是PHP如何使用文件锁解决高并发问题的详细内容,其它编程语言
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答