Maison > développement back-end > Problème PHP > Quelles sont les techniques de gestion de la concurrence en PHP ?

Quelles sont les techniques de gestion de la concurrence en PHP ?

(*-*)浩
Libérer: 2023-02-25 22:48:01
original
2363 Les gens l'ont consulté

Les exemples de cet article décrivent plusieurs méthodes d'implémentation pour résoudre les problèmes de concurrence dans le développement PHP. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Quelles sont les techniques de gestion de la concurrence en PHP ?

Dans des scénarios simultanés tels que l'achat précipité de produits, une survente peut se produire, vous devez alors résoudre les problèmes causés par la concurrence

Il n'existe pas de solution de concurrence native dans le langage PHP, vous devez donc utiliser d'autres méthodes pour obtenir un contrôle de concurrence.

Option 1 : Utiliser le verrouillage exclusif de verrouillage de fichier (Apprentissage recommandé : Tutoriel vidéo PHP)

La fonction flock est utilisée pour obtenir le verrouillage de fichier . Ce verrou ne peut être acquis que par un seul thread à la fois. Les autres threads qui n'ont pas acquis le verrou sont soit bloqués, soit n'ont pas réussi à l'acquérir

Lors de l'acquisition du verrou, interrogez d'abord l'inventaire. l'inventaire est supérieur à 0, passez une commande. Opérez, réduisez l'inventaire, puis libérez le verrou

Option 2 : utilisez le verrou pessimiste fourni par la base de données Mysql

Le moteur de stockage Innodb prend en charge les verrous au niveau de la ligne. Lorsqu'une ligne de données est verrouillée. Lorsque les autres processus ne peuvent pas fonctionner sur cette ligne de données.

Interrogez et verrouillez d'abord la ligne :

select stock_num from table where id=1 for update
if(stock_num > 0){
//下订单
update table set stock_num=stock-1 where id=1
}
Copier après la connexion

<🎜. >Option 3 : Utiliser une file d'attente

pour transférer les demandes de commande de l'utilisateur à leur tour dans une file d'attente et un processus distinct est utilisé en arrière-plan pour traiter les demandes de commande dans la file d'attente

Option 4 : Utiliser Redis

Les opérations de redis sont toutes atomiques. Vous pouvez stocker l'inventaire des marchandises dans redis Avant de passer une commande, effectuez une opération de diminution. sur l'inventaire. Si la valeur renvoyée est supérieure ou égale à 0, vous pouvez passer une commande. Sinon, vous ne pouvez pas passer une commande

if(redis->get(&#39;stock_num&#39;) > 0){
 stock_num = redis->decr(&#39;stock_num&#39;)
 if(stock_num >= 0){
 //下订单
 }else{
 //库存不足
 }
}else{
//库存不足
}
Copier après la connexion

Autres problèmes de concurrence :

Dans les applications réelles, dans de nombreux cas, les données seront stockées dans le cache. Lorsque le cache échoue, accédez à la base de données pour récupérer les données et réinitialiser le cache. est très volumineux, et de nombreux processus seront envoyés à la base de données pour récupérer des données en même temps, ce qui entraînera de nombreuses requêtes

pénétrant dans la base de données, provoquant le crash de la base de données. Les verrous de fichiers peuvent être utilisés pour résoudre. ce problème

$data = $cache->get(&#39;key&#39;);
if(!$data){
  $fp = fopen(&#39;lockfile&#39;);
  if(flock($fp, LOCK_EX)){
    $data = $cache->get(&#39;key&#39;);//拿到锁后再次检查缓存,这时可能已经有了
    if(!$data){
      $data = mysql->query();
      $cache->set(&#39;key&#39;, $data);
    }
    flock($fp, LOCK_UN);
  }
  fclose($fp);
}
Copier après la connexion

Pour parler franchement, le verrouillage est nécessaire pour résoudre les problèmes de concurrence. L'essence de diverses solutions est le verrouillage.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal