Maison >développement back-end >Problème PHP >Introduction détaillée aux cinq modèles d'E/S de PHP : bloquants et non bloquants

Introduction détaillée aux cinq modèles d'E/S de PHP : bloquants et non bloquants

醉折花枝作酒筹
醉折花枝作酒筹avant
2021-06-08 17:37:062599parcourir

Cet article vous donnera une introduction détaillée au blocage et au non-blocage des cinq principaux modèles d'E/S de PHP. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Introduction détaillée aux cinq modèles d'E/S de PHP : bloquants et non bloquants

Blocage : signifie que l'application doit terminer l'opération IO avant de retourner dans l'espace utilisateur.

Non bloquant : signifie que l'application est bloquée lorsque réalisation de l'opération IO Une valeur d'état est renvoyée à l'utilisateur immédiatement après l'appel sans attendre que l'opération IO soit complètement terminée.

Modèle bloquant :

Introduction détaillée aux cinq modèles dE/S de PHP : bloquants et non bloquants

Mode non bloquant :

Introduction détaillée aux cinq modèles dE/S de PHP : bloquants et non bloquants

En mode bloquant, l'utilisateur le processus continuera d'attendre les données sur l'état du noyau, l'efficacité est donc extrêmement faible. Par exemple : lorsque Xiao Ming veut faire bouillir de l'eau, il doit attendre que l'eau bout. Mais en fait, Xiao Ming peut faire autre chose pendant le processus d'ébullition de l'eau.

Une optimisation est en mode non bloquant. Une fois que le processus utilisateur a effectué une opération d'E/S, l'état du noyau renvoie immédiatement une valeur, qui est généralement vide. Le processus utilisateur peut faire autre chose jusqu'à ce que les données d'état du noyau soient. prêt. Demande pour obtenir les résultats réels de l’exécution. En prenant l'exemple de Xiao Ming ci-dessus, lorsque Xiao Ming fait bouillir de l'eau, il peut lire un livre, regarder pendant un moment si l'eau bout, vérifier si l'eau bout, et en même temps il peut lire un livre. et étudier.

Analyse des performances :

Supposons qu'un programme doive effectuer deux opérations a et b, où a doit effectuer des opérations d'E/S et b non. En mode bloquant, le temps consommé est égal à a+b, tandis qu'en mode non bloquant, il est égal au temps maximum d'opération en a et b.

Code serveur :

$server = stream_socket_server('tcp://127.0.0.1:9999', $erron, $error);
while (true) {
 $conn = stream_socket_accept($server);
 if ($conn) {
 $data = fread($conn, 65535);
 echo $data;
 sleep(3);
 fwrite($conn, 'this is server');
 fclose($conn);
 }
}

Client bloquant :

function operation()
{
 sleep(2);
}
echo "client start n";
$client =  stream_socket_client('tcp://127.0.0.1:9999', $erron, $error, 60);
fwrite($client, "is client 1n");
echo fread($client, 65535);
operation();
fclose($client);

Client non bloquant :

function operation()
{
 sleep(2);
}
echo "client start n";
$client =  stream_socket_client('tcp://127.0.0.1:9999', $erron, $error, 60);
stream_set_blocking($client, 0);//设置非阻塞
fwrite($client, "is client 1n");
operation();
while (!feof($client)) {
 sleep(1);
 var_dump(fread($client, 65535));
}
fclose($client);

Consommation de temps :

Mode de blocage

Introduction détaillée aux cinq modèles dE/S de PHP : bloquants et non bloquants

Mode non bloquant

Introduction détaillée aux cinq modèles dE/S de PHP : bloquants et non bloquants

Apprentissage recommandé : Tutoriel vidéo php

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer