PHP はファイル ロックを使用して同時実行性の問題を解決します

零到壹度
リリース: 2023-03-22 11:32:01
オリジナル
2344 人が閲覧しました

今回は、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,&#39;SELECT total FROM shop WHERE id=1 LIMIT 1&#39;)); <br/>      if($res[&#39;total&#39;]>0){mysqli_query($con,&#39;UPDATE shop SET total=total-1  WHERE id=1&#39;);}    //执行完成解锁<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,&#39;SELECT total FROM shop WHERE id=1 LIMIT 1&#39;));   <br/>    if($res[&#39;total&#39;]>0){mysqli_query($con,&#39;UPDATE shop SET total=total-1  WHERE id=1&#39;);}   <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 サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート