Qu'est-ce qu'epoll ? Dans la programmation réseau de linux, select est utilisé depuis longtemps pour le déclenchement d'événements. Dans le nouveau noyau Linux, il existe un mécanisme pour le remplacer, epoll. Bien sûr, cela n'est pas propre au noyau 2.6, il a été introduit dans le noyau 2.5.44 (epoll(4) est une nouvelle API introduite dans le noyau Linux 2.5.44) , elle présente presque tous les avantages mentionnés précédemment et est reconnue comme la méthode de notification d'E/S multiplexée la plus performante sous Linux2.6.
Par rapport à Select, le plus grand avantage d'epoll est qu'il ne réduira pas l'efficacité à mesure que le nombre de fds d'écoute augmente. Parce que dans l'implémentation select dans le noyau, il est traité par interrogation. Plus il y a de fds interrogés, plus cela prendra de temps.
epoll notifie également uniquement les descripteurs de fichiers prêts, et lorsque nous appelons epoll_wait() pour obtenir un descripteur de fichier prêt, ce qui est renvoyé n'est pas le descripteur réel, mais une valeur représentant le nombre de descripteurs prêts. Il vous suffit d'obtenir le nombre correspondant de descripteurs de fichiers en séquence à partir d'un tableau spécifié par epoll. La technologie de mappage de mémoire (mmap) est également utilisée ici, de sorte qu'elle soit complètement celle-ci. élimine la surcharge liée à la copie de ces descripteurs de fichiers lors des appels système.
Une autre amélioration essentielle est qu'epoll adopte une méthode de notification de préparation basée sur les événements. Dans select/poll, le noyau analyse tous les descripteurs de fichiers surveillés uniquement après que le processus a appelé une certaine méthode, tandis qu'epoll enregistre un descripteur de fichier via epoll_ctl() à l'avance. Une fois qu'un certain descripteur de fichier est prêt, le noyau utilisera un mécanisme de rappel. similaire au rappel pour activer rapidement ce descripteur de fichier, et sera averti lorsque le processus appellera epoll_wait().
Comme le montre ce qui précède, epoll est une amélioration par rapport aux modèles select et poll, qui améliore les performances de la programmation réseau et est largement utilisé dans les requêtes simultanées à grande échelle C/SArchitecture.
Déclencheur Edge/déclencheur horizontal, applicable uniquement au système d'exploitation Unix/Linux
Créer un epoll objet——Créer 1 epollObjet
Dites à l'objet epoll de surveiller des événements spécifiques sur des sockets spécifiques——Dites à l'objet epoll de surveiller des événements spécifiques sur des sockets spécifiques
Demandez à l'objet epoll quelles sockets peuvent avoir le spécifié événement depuis la dernière requête——Demandez à l'objet epoll quelles sockets ont eu l'événement spécifié depuis la dernière requête
Effectuez une action sur ces sockets—— Effectuez quelques opérations sur ces sockets
Dites à l'objet epoll de modifier la liste des sockets et/ou des événements à surveiller——Dites à l'objet epoll de modifier la liste des sockets et/ou des événements, et Monitor
Répétez les étapes 3 à 5 jusqu'à ce que vous ayez terminé——Répétez les étapes 3 à 5 jusqu'à ce que vous ayez terminé
Détruisez l'objet epoll——Détruisez l'objet epoll
importer. select Import select module
epoll = select.epoll() crée un objet epoll
epoll.register (descripteur de fichier, type d'événement) enregistre le descripteur de fichier à surveiller et Event
Type d'événement :
select.EPOLLIN Événement lisible
select.EPOLLOUT Événement inscriptible
select.EPOLLERR Événement d'erreur
Rapport au processus utilisateur, timeout
est le délai d'expiration, la valeur par défaut est -1, c'est-à-dire que le descripteur de fichier est modifié jusqu'à ce que le descripteur de fichier change, s'il est spécifié comme 1
alors le descripteur de fichier actuel est signalé toutes les 1 secondes toutes les 1 secondes. S'il n'y a pas de changement, il retournera vide
epoll.fileno() Renvoie le descripteur du fichier de contrôle epoll (
Retourle descripteur du fichier de contrôle epoll)
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!