ホームページ >バックエンド開発 >PHPチュートリアル >PHP はファイル ロックを使用して同時実行性の問題を解決します
今回は、Tphp がファイル ロックを使用して同時実行性の高い問題を解決する方法について説明します。PHP がファイル ロックを使用して同時性の高い問題を解決する際の注意点は何ですか? ここでは実際のケースを見てみましょう。
ファイルには何も書き込まずに、新しい .txt ファイルを作成します。
【1つ】.ブロッキング(待機)モード: (他のプロセスがファイルをロックしている限り、現在のプロセスは他のプロセスがファイルのロックを解除するのを待ちます)
<span style="font-family: 微软雅黑, "Microsoft YaHei"; font-size: 14px;"> <?php<br/> //连接数据库<br/> $con=mysqli_connect("192.168.2.186","root","root","test");<br/> //查询商品数量是否大于0,大于0才能下单,并减少库存<br/> $fp = fopen("lock.txt", "r");<br/> //加锁<br/> if(flock($fp,LOCK_EX))<br/>{ <br/> $res=mysqli_fetch_assoc(mysqli_query($con,'SELECT total FROM shop WHERE id=1 LIMIT 1')); <br/> if($res['total']>0){mysqli_query($con,'UPDATE shop SET total=total-1 WHERE id=1');} //执行完成解锁<br/> flock($fp,LOCK_UN);<br/>}<br/>//关闭文件<br/>fclose($fp);<br/>unset($res);<br/>mysqli_close($con);<br/>?><br/></span>
【2つ】.ノンブロッキング (待機) モード: (他のプロセスがファイルをロックしている限り、現在のプロセスは他のプロセスがファイルのロックを解除するのを待たずに直接戻ります)
<span style="font-family: 微软雅黑, "Microsoft YaHei"; font-size: 14px;"> <?php<br/> //连接数据库<br/> $con=mysqli_connect("192.168.2.186","root","root","test");<br/> //查询商品数量是否大于0,大于0才能下单,并减少库存<br/> $fp = fopen("lock.txt", "r");<br/> //加锁if(flock($fp,LOCK_EX | LOCK_NB))<br/>{ <br/> $res=mysqli_fetch_assoc(mysqli_query($con,'SELECT total FROM shop WHERE id=1 LIMIT 1')); <br/> if($res['total']>0){mysqli_query($con,'UPDATE shop SET total=total-1 WHERE id=1');} <br/> //执行完成解锁<br/> flock($fp,LOCK_UN);<br/>}//关闭文件<br/>fclose($fp);<br/>unset($res);<br/>mysqli_close($con);<br/>?></span>
データベースへの接続に時間がかかる場合、以下に簡単なデモがあり、より直感的に理解できます。
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);
2 つのファイルを同時に実行し、demo2 でロック機構を変更すると、ブロッキング (待機) モード と 非ブロッキング (待機) モード
の違いがわかります。
しかし、これによりキューがブロックされます。10 人が同時にデータベースに書き込むと、10 人目は最初の 9 人が実行されるまでブロックされます。
以上がPHP はファイル ロックを使用して同時実行性の問題を解決しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。