Maison >développement back-end >PHP7 >Modèle d'E/S de l'analyse du noyau PHP7
1. Synchronisation : Mon client (appelant côté C) a une fonction avant la fin de la fonction, j'attends le résultat.
2. Asynchrone : j'appelle une fonction (l'appelant côté C) et je ne connais pas le résultat de la fonction, lorsque la fonction aura le résultat, je serai averti, c'est-à-dire une notification de rappel <.>
3. Blocage : Appelez simplement I (l'appelé du côté s, fonction), je (l'appelé du côté s, la fonction) ne reviendra pas tant que j'aurai complètement accepté les données ou obtenu le résultat. 4. Non bloquant : cela signifie m'appeler (appelé du côté, fonction), je (appelé du côté, fonction) revient immédiatement et informe l'appelant après avoir obtenu le résultatCinq modèles d'E/S
(1) Blocage des E/S (Blocage des E/S)
Technologie de multiplexage d'E/S
select(1).select() fournit une structure de données de fd_set, Chaque élément peut établir une connexion avec un descripteur de fichier ouvert (qu'il s'agisse d'un descripteur de Socket, d'un autre fichier ou d'un canal nommé ou d'un descripteur de périphérique). Le travail d'établissement de la connexion est effectué par le programmeur. Lorsque select() est appelé, le noyau détermine la connexion en fonction du descripteur. IO Le statut modifie le contenu de fd_set, informant ainsi le processus qui a exécuté select() quel Socket ou quel fichier est lisible ou inscriptible. Principalement utilisé pour la communication Socket. (2). Une fois la sélection exécutée, s'il n'y a pas d'entrée de données, le programme attendra (lorsqu'il est bloqué) jusqu'à ce qu'il y ait des données, c'est-à-dire qu'il n'est pas nécessaire de faire des boucles et de dormir dans le programme. . (3). Chaque fois que select est appelé, la collection fd_set doit être copiée du mode utilisateur vers le mode noyau. Cette surcharge sera très importante lorsqu'il y a plusieurs (4). ). Dans le même temps, chaque fois que l'appel de select nécessite que le noyau traverse tous les fd_sets transmis. Cette surcharge est également très importante lorsqu'il existe de nombreux fd_sets(5). est trop petit. La valeur par défaut est 1024poll
(1) L'implémentation de poll est très similaire à select, sauf que la façon de décrire la collection fd_set. est différent. poll utilise la structure de liste chaînée pollfd au lieu de la structure fd_set de select. (2). Pas de limite supérieure sur le nombre de descripteurs de surveillanceepoll/kqueue
(1). nombre de descripteurs de surveillance ;(2). L'efficacité est améliorée, ce n'est pas une méthode d'interrogation, et l'efficacité ne diminuera pas à mesure que le nombre de fd augmente. Seuls les fds actifs et disponibles appelleront la fonction de rappel ; c'est-à-dire que le plus grand avantage de epoll/kqueue est qu'il ne se soucie que de vos connexions "actives" et n'a rien à voir avec le nombre total de connexions, par conséquent, dans le réseau réel. environnement, l'efficacité d'epoll/kqueue sera beaucoup plus élevée que celle de select et poll. (3). Copie de mémoire, utilisant la mémoire de mappage de fichiers mmap() pour accélérer la transmission des messages avec l'espace du noyau ;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!