Cet article est basé sur le langage PHP et utilise le verrouillage pour implémenter la fonction d'achat urgent dans des circonstances concurrentes. L'achat urgent est ouvert pendant une période de temps spécifique et ne permet pas la duplication de codes ouverts. Cet article est très détaillé, n'hésitez pas à vous y référer si vous en avez besoin. J'espère que cela aide tout le monde.
Exigences : fonction de saisie de code
Exigences :
1. La saisie de code n'est ouverte que pendant une période spécifique
2. Les codes publiés dans chaque période sont limités
3. Chaque code ne peut pas être répété
Réalisation :
1. Implémenté sans tenir compte de la concurrence :
<p style="margin-top: 5px; margin-bottom: 5px;">function get_code($len){<br/>$CHAR_ARR = array('1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','X','Y','Z','W','S','R','T');<br/>$CHAR_ARR_LEN = count($CHAR_ARR) - 1;<br/>$code = '';<br/>while(--$len > 0){ $code .= $CHAR_ARR[rand(0,$CHAR_ARR_LEN)]; }<br/>return $code;<br/>}<br/>$pdo = new PDO('mysql:host=localhost;dbname=ci_test','root','root');<br/>//查询当前时间已发放验证码数量<br/>$code_num_rs = $pdo->query("SELECT COUNT(*) as sum FROM code_test");<br/>$code_num_arr = $code_num_rs->fetch(PDO::FETCH_ASSOC);<br/>$code_num = $code_num_arr['sum'];<br/>if($code_num < 1){<br> sleep(2); //暂停2秒<br/>$code = get_code(6);<br/>var_dump( $pdo->query("INSERT INTO code_test (code,create_time) VALUES ('$code',".time().")") );<br/>}<br/></p>
Le code ci-dessus satisfait à l'heure d'ouverture actuelle par défaut, et le code n'est pas répété
Sans tenir compte de la concurrence ;
1) Sélectionnez et interrogez le nombre de codes de vérification émis par la base de données actuelle
2) S'il reste des places, générez le code de vérification, insérez-le dans la base de données et renvoyer le code de vérification au client ;
3) S'il est plein ; renvoyer un message indiquant qu'il n'y a plus de places
2. Mis en œuvre dans des situations concurrentes :
Jetez ensuite un œil aux résultats obtenus par le code ci-dessus dans le cas de la concurrence :
Pour tester la concurrence, vous pouvez utiliser Apache Benchmark pour test. apache benchmark est l'outil d'évaluation des performances du SERVEUR HTTP sous APACHE, via cmd Entrez le répertoire bin d'apche et appelez-le via la commande ab, telle que : ab -c nombre simultané -n url total des visites
<p style="margin-top: 5px; margin-bottom: 5px;">cb -c 100 -n 100 http://localhost/php_mulit.php<br/></p>
De cette façon, 100 utilisateurs et collègues récupéreront 1 quota. À ce moment-là, si chaque utilisateur constate qu'il y a encore un quota, le code de vérification sera généré, inséré dans la base de données, et le code de vérification sera généré. sera renvoyé ; cela entraînera l’envoi d’un trop grand nombre de codes de vérification. En fait, après avoir exécuté cette commande, la base de données contient 13 enregistrements supplémentaires au lieu d'un.
Comment éviter que cela se produise ?
Vous pouvez verrouiller le processus du jugement à l'insertion en ajoutant un verrou exclusif pour garantir qu'un seul processus est en cours d'exécution dans ce processus de jugement à tout moment. La mise en œuvre est la suivante :
<p style="margin-top: 5px; margin-bottom: 5px;">//生成码<br/>function get_code($len){<br/>$CHAR_ARR = array('1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','X','Y','Z','W','S','R','T');<br/>$CHAR_ARR_LEN = count($CHAR_ARR) - 1;<br/>$code = '';<br/>while(--$len > 0){ $code .= $CHAR_ARR[rand(0,$CHAR_ARR_LEN)]; }<br/>return $code;<br/>}<br/>$pdo = new PDO('mysql:host=localhost;dbname=ci_test','root','root');<br/>$fp = fopen('lock.txt','r');<br/>//通过排他锁 锁定该过程<br/>if(flock($fp,LOCK_EX)){<br/>//查询当前时间已发放验证码数量<br/>$code_num_rs = $pdo->query("SELECT COUNT(*) as sum FROM code_test");<br/>$code_num_arr = $code_num_rs->fetch(PDO::FETCH_ASSOC);<br/>$code_num = $code_num_arr['sum'];<br/>if($code_num < 1){<br/>sleep(2);<br/>$code = get_code(6);<br/>var_dump( $pdo->query("INSERT INTO code_test (code,create_time) VALUES ('$code',".time().")") );<br/>}<br/>flock($fp,LOCK_UN);<br/>fclose($fp);<br/>}<br/></p>
Verrouillez le processus via la fonction flock.
Exécutez-le à nouveau
<p style="margin-top: 5px; margin-bottom: 5px;">cb -c 100 -n 100 http://localhost/php_mulit.php<br/></p>
Un seul enregistrement est ajouté à la base de données, garantissant que les données sont correctes en cas de simultanéité.
Recommandations associées :
Exploration approfondie pour savoir si php continuera à s'exécuter après la fermeture du navigateur
Exemple de la façon dont PHP implémente le carnet d'adresses en ligne
Comparaison d'exemples de la façon dont PHP peut lire efficacement des fichiers volumineux
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!