PHP がファイル ロックを使用して同時実行性の高い問題を解決する方法

小云云
リリース: 2018-03-30 10:16:01
オリジナル
2270 人が閲覧しました

この記事では、主に PHP でのファイル ロックの使用法を紹介し、高同時性の問題を解決するための PHP ブロッキング モードと非ブロッキング モードのファイル ロックの関連使用スキルを例の形で分析します。参考になれば幸いです。

ファイルには何も書き込まずに、新しい .txt ファイルを作成します。

【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,&#39;SELECT total FROM shop WHERE id=1 LIMIT 1&#39;));
  if($res[&#39;total&#39;]>0){mysqli_query($con,&#39;UPDATE shop SET total=total-1 WHERE id=1&#39;);}
  //执行完成解锁
  flock($fp,LOCK_UN);
}
//关闭文件
fclose($fp);
unset($res);
mysqli_close($con);
?>
ログイン後にコピー

【2つ】. ノンブロッキング(待機)モード: (他のプロセスがファイルをロックしている限り、現在のプロセスは他のプロセスがファイルのロックを解除して直接戻るのを待ちません


<?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,&#39;SELECT total FROM shop WHERE id=1 LIMIT 1&#39;));
  if($res[&#39;total&#39;]>0){mysqli_query($con,&#39;UPDATE shop SET total=total-1 WHERE id=1&#39;);}
  //执行完成解锁
  flock($fp,LOCK_UN);
}
//关闭文件
fclose($fp);
unset($res);
mysqli_close($con);
?>
ログイン後にコピー

)データベースへの接続に時間がかかる場合は、簡単なデモを使用すると、より直観的に理解できるようになります。

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.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!