Maison  >  Article  >  développement back-end  >  Plusieurs implémentations de PHP pour résoudre les problèmes de concurrence

Plusieurs implémentations de PHP pour résoudre les problèmes de concurrence

不言
不言original
2018-04-19 15:06:002528parcourir

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);  
}


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

Connexe. recommandations :

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!

Déclaration:
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