Maison > Article > développement back-end > Plusieurs implémentations de PHP pour résoudre les problèmes de concurrence
Cet article présente plusieurs implémentations de PHP pour résoudre les problèmes de concurrence. Il a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer
Pour les scénarios de concurrence tels que les rushes de produits. Dans cette situation, une survente peut se produire. À l'heure actuelle, vous devez 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.
Option 1 : Utiliser le verrouillage exclusif du verrouillage de fichier
La fonction flock est utilisée pour acquérir le verrouillage de fichier. Ce verrou ne peut être acquis que par un seul thread à la fois. acquis, le verrou sera soit bloqué. , soit l'acquisition échoue
Lors de l'acquisition du verrou, interrogez d'abord l'inventaire si l'inventaire est supérieur à 0, passez une commande, réduisez l'inventaire, puis libérez le verrou.
Option 2 : Utiliser 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. , les autres processus ne peuvent pas opérer sur la ligne de données
Première requête et verrouiller la ligne : sélectionnez stock_num dans la table où id=1 pour la mise à jour
if(stock_num > 0){ //下订单 update table set stock_num=stock-1 where id=1 }
Option 3 : Utiliser la file d'attente
pour stocker les demandes de commande de l'utilisateur dans une file d'attente en séquence, en arrière-plan Utiliser un processus distinct pour traiter les demandes de commande dans la file d'attente
Option 4 : Utiliser Redis
Les opérations Redis sont toutes atomiques et les marchandises peuvent être stockées 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, la commande peut. être passée. Sinon, la commande ne peut pas être passée. Cette méthode est plus efficace
if(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 nombreuses Les données des cas 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. En cas de simultanéité, le volume est très volumineux et de nombreux processus seront envoyés à la base de données pour récupérer les données. en même temps, ce qui entraîne la pénétration de nombreuses requêtes
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
[php] voir en clair copier
$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); }
php résout le problème de perte lors de la publication de grandes quantités de données
PHP résout le blocage des fichiers de session
PHP résout le problème d'affichage chinois JSON
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!