Maison > Article > développement back-end > Modèle d'E/S d'analyse du noyau PHP7 2
Le contenu de cet article concerne le modèle d'E/S de PHP7 Kernel Analysis 2. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer
1. ) L'appelant) est une fonction qui ne se termine pas avant que je meurs en attendant 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 a le résultat, elle m'en informera, c'est-à-dire une notification de rappel
3. Bloquer : cela signifie m'appeler (le côté s est appelé (ou, fonction), je (appelé côté s, fonction) ne reviendra pas tant que j'aurai complètement accepté les données ou obtenu le résultat.
4. Non bloquant : appelez-moi simplement (appelé du côté, fonction), je (appelé du côté, fonction) reviendrai immédiatement et informerai l'appelant après avoir obtenu le résultat
Cinq modèles d'E/S
(1) Blocage des E/S (Blocage des E/S)
Quand Lorsque le processus utilisateur effectue un appel système, le noyau démarre la première étape des E/S et prépare les données dans le tampon. Lorsque les données sont préparées, les données sont copiées du tampon du noyau vers la mémoire du processus utilisateur. À ce moment-là, le processus utilisateur est libéré de l'état de blocage et s'exécute à nouveau.
(2) E/S non bloquantes
Le processus utilisateur n'est que dans la seconde L'étape est bloquée, tandis que la première étape n'est pas bloquée, mais dans la première étape, le processus utilisateur n'a pas besoin d'attendre aveuglément et interroge constamment le noyau pour voir si les données sont prêtes, donc ce modèle consomme plus de CPU.
(3) Multiplexage d'E/S
Les deux étapes de l'exécution des E/S sont Les deux processus utilisateur sont bloqués, mais le deux étapes sont indépendantes. Dans une opération d'E/S complète, le processus utilisateur lance deux appels système. La différence avec le blocage des E/S est que le premier segment peut attendre que plusieurs descripteurs soient prêts
(4) E/S pilotées par signal (E/S pilotées par signal)
Bloque le processus utilisateur uniquement lors de la deuxième étape de l'exécution des E/S, mais n'est pas bloqué lors de la première étape. Dans la première étape de l'exécution des E/S, ce modèle informera activement le processus utilisateur que les données ont été préparées une fois la préparation des données terminée, c'est-à-dire qu'il rappellera le processus utilisateur. Il existe deux types de notifications, l'une est à déclenchement horizontal, c'est-à-dire que les notifications seront envoyées à tout moment si le processus utilisateur ne répond pas, et l'autre est à déclenchement sur front, qui n'est notifié qu'une seule fois.
(5) E/S asynchrones (E/S asynchrones)
Lorsque le processus utilisateur lance un appel système, il immédiatement Vous pouvez commencer à faire autre chose, puis jusqu'à ce que les deux étapes de l'exécution des E/S soient terminées, le noyau enverra une notification au processus utilisateur pour indiquer au processus utilisateur que l'opération est terminée.
Technologie de multiplexage d'E/S
select
(1).select() fournit une structure de données de fd_set dans le mécanisme. é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. selon l'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 1024
poll
(1). L'implémentation de poll est très similaire à celle de select, sauf que la façon de décrire la collection fd_set est différente. utilise la structure de liste chaînée pollfd au lieu de la structure fd_set de select. Tout le reste est similaire.
(2). Aucune limite supérieure sur le nombre de descripteurs de surveillance ;
epoll/kqueue
(1). 🎜>(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, utilisez la mémoire de mappage de fichiers mmap() pour accélérer la transmission des messages avec l'espace du noyau
PHP7 Kernel Analysis 1 CGI et FastCGI ;
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!