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 :
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 }
<🎜. >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'attenteOption 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 commandeif(redis->get('stock_num') > 0){ stock_num = redis->decr('stock_num') if(stock_num >= 0){ //下订单 }else{ //库存不足 } }else{ //库存不足 }
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('key'); if(!$data){ $fp = fopen('lockfile'); if(flock($fp, LOCK_EX)){ $data = $cache->get('key');//拿到锁后再次检查缓存,这时可能已经有了 if(!$data){ $data = mysql->query(); $cache->set('key', $data); } flock($fp, LOCK_UN); } fclose($fp); }
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!