Table des matières
Quelle est la différence entre poll et select sous Linux ?
Maison Opération et maintenance exploitation et maintenance Linux Quelle est la différence entre sondage et sélection sous Linux ?

Quelle est la différence entre sondage et sélection sous Linux ?

Jul 11, 2022 pm 05:00 PM
linux

La différence entre poll et select sous Linux est la suivante : le nombre maximum de connexions pouvant être ouvertes par un seul processus de sélection est défini par la macro "FD_SETSIZE", et sa taille est de 32 entiers, tandis que poll utilise le stockage de liste chaînée, donc il n’y a pas de limite maximale de connexions.

Quelle est la différence entre sondage et sélection sous Linux ?

L'environnement d'exploitation de ce tutoriel : système linux7.3, ordinateur Dell G3.

Quelle est la différence entre poll et select sous Linux ?

La sélection utilisée par chaque processus a une limite sur le nombre maximum de connexions, qui ne peut être que FD_SETSIZE, alors que poll n'a pas une telle restriction (en utilisant le stockage de liste chaînée) ;

epoll et select peuvent tous deux être fournis. Solution pour les E/S multiplexées. Tous peuvent être pris en charge dans le noyau Linux actuel, parmi lesquels epoll est unique à Linux, tandis que select doit être stipulé par POSIX et implémenté dans les systèmes d'exploitation généraux

select :

select est essentiellement stocké via des paramètres ou des vérifications. Les données. La structure du bit d'indicateur fd est utilisée pour l'étape suivante du traitement. Les inconvénients sont les suivants :

1. Le nombre de fds pouvant être surveillés par un seul processus est limité, c'est-à-dire que la taille du port d'écoute est limitée.

De manière générale, ce numéro est étroitement lié à la mémoire système. Le numéro spécifique peut être consulté par cat /proc/sys/fs/file-max. La valeur par défaut pour les machines 32 bits est 1024. La valeur par défaut pour les machines 64 bits est 2048.

2. Lors de l'analyse du socket, il s'agit d'un scan linéaire, c'est-à-dire que la méthode d'interrogation est utilisée, ce qui est moins efficace :

Lorsqu'il y a plusieurs sockets, select() doit être transmis à chaque fois que Traverse FD_SETSIZE Sockets pour terminer la planification. Quel que soit le Socket actif, tous sont parcourus. Cela gaspille beaucoup de temps CPU. Si vous pouvez enregistrer une fonction de rappel pour le socket et effectuer automatiquement les opérations associées lorsqu'elles sont actives, alors l'interrogation est évitée. C'est ce que font epoll et kqueue.

3. Il est nécessaire de maintenir une structure de données pour stocker un grand nombre de fd, ce qui entraînera une surcharge de copie élevée lors du transfert de la structure entre l'espace utilisateur et l'espace noyau.

poll :

poll est essentiellement le même. comme select.Ce sera Le tableau transmis par l'utilisateur est copié dans l'espace du noyau, puis l'état du périphérique correspondant à chaque fd est interrogé. Si le périphérique est prêt, un élément est ajouté à la file d'attente du périphérique et la traversée continue. . Si aucun périphérique prêt n'est trouvé après avoir parcouru tous les fd, le système se bloque, jusqu'à ce que le périphérique soit prêt ou que l'initiative expire, parcourra à nouveau le fd après avoir été réveillé. Ce processus a traversé de nombreuses traversées inutiles.

Il n'a pas de limite sur le nombre maximum de connexions car il est stocké sur la base d'une liste chaînée, mais il a aussi un inconvénient :

1 Un grand nombre de tableaux fd sont copiés dans leur ensemble entre le mode utilisateur et le mode utilisateur. l'espace d'adressage du noyau, quel que soit l'espace d'adressage du noyau. Une telle réplication a-t-elle un sens ?​​​​​​​​​​​

2. Une autre fonctionnalité du sondage est le "déclenchement horizontal". Si un fd est signalé mais n'est pas traité, le fd sera à nouveau signalé la prochaine fois qu'il sera interrogé.

epoll :

epoll a deux modes de déclenchement : EPOLLLT et EPOLLET LT est le mode par défaut et ET est le mode "haute vitesse". En mode LT, tant que le fd a encore des données à lire, epoll_wait renverra son événement à chaque fois pour rappeler au programme utilisateur de fonctionner. En mode ET (déclencheur sur front), il ne demandera qu'une seule fois jusqu'à ce qu'il y ait des données ensuite. Il n'y aura plus d'invite avant l'afflux, qu'il y ait ou non encore des données lisibles dans fd. Par conséquent, en mode ET, lors de la lecture d'un fd, son tampon doit être lu, c'est-à-dire jusqu'à ce que la valeur de retour de lecture soit inférieure à la valeur demandée, ou qu'une erreur EAGAIN soit rencontrée. Une autre fonctionnalité est qu'epoll utilise la méthode de notification de préparation "événement" pour enregistrer le fd via epoll_ctl. Une fois le fd prêt, le noyau utilisera un mécanisme de rappel de type rappel pour activer le fd, et epoll_wait pourra recevoir la notification.

Pourquoi epoll a-t-il le mode de déclenchement EPOLLET ?

Si le mode EPOLLLT est adopté, une fois qu'il y aura un grand nombre de descripteurs de fichiers prêts dans le système que vous n'avez pas besoin de lire ou d'écrire, ils reviendront à chaque appel de epoll_wait, ce qui réduira considérablement l'efficacité du gestionnaire pour récupérer les descripteurs de fichiers prêts qui l'intéressent. Si le mode de déclenchement sur front d'EPOLLET est utilisé, lorsqu'un événement lisible et inscriptible se produit sur le descripteur de fichier surveillé, epoll_wait() demandera au gestionnaire de lire et d'écrire. Si toutes les données ne sont pas lues et écrites cette fois (par exemple, le tampon de lecture-écriture est trop petit), il ne vous en informera pas la prochaine fois que vous appellerez epoll_wait(), c'est-à-dire qu'il ne vous en informera qu'une seule fois jusqu'à ce que le descripteur de fichier est Vous ne serez pas averti jusqu'à ce que le deuxième événement lisible et inscriptible se produise ! ! ! Ce mode est plus efficace que le déclenchement horizontal, et le système ne sera pas inondé d'un grand nombre de descripteurs de fichiers prêts dont vous ne vous souciez pas. Avantages d'epoll :

1. , et la limite supérieure des FD pouvant être ouverts est bien supérieure à 1024 (1 Go de mémoire peut surveiller environ 100 000 ports)

2 L'efficacité est améliorée, ce n'est pas une méthode d'interrogation et l'efficacité ne diminuera pas au fur et à mesure ; le nombre de FD augmente. Seuls les FD actifs et disponibles appelleront la fonction de rappel ;

Le plus grand avantage d'Epoll 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 l'environnement réseau réel, le nombre total de connexions est important. l'efficacité d'Epoll sera bien supérieure à celle de la sélection et du sondage.

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 ; c'est-à-dire qu'epoll utilise mmap pour réduire la surcharge de copie.

Select, poll, epoll Résumé des différences :

1 Prend en charge le nombre maximum de connexions pouvant être ouvertes par un processus

select

Le nombre maximum de connexions pouvant être ouvertes par un seul. Le processus est défini par la macro FD_SETSIZE, et sa taille est de 32 entiers (sur une machine 32 bits, la taille est de 3232, et de même sur une machine 64 bits, FD_SETSIZE est de 3264). modifiez-le et recompilez le noyau, mais les performances peuvent être affectées, ce qui nécessite des tests supplémentaires.

poll

poll est essentiellement la même chose que select, mais il n'a pas de limite sur le nombre maximum de connexions, car il est stocké sur la base d'une liste chaînée

epoll

Bien qu'il y ait une limite supérieure sur le nombre de connexions, il est très grand, une machine avec 1G de mémoire Elle peut ouvrir environ 100 000 connexions, et une machine avec 2G de mémoire peut ouvrir environ 200 000 connexions

2 problèmes d'efficacité IO causés par la forte augmentation de FD

select.

Parce que la connexion sera traitée à chaque fois qu'elle est appelée Traversée linéaire, donc à mesure que FD augmente, cela provoquera un "problème de performances de déclin linéaire" avec une vitesse de traversée lente.

poll

Idem que ci-dessus

epoll

Étant donné que l'implémentation dans le noyau epoll est basée sur la fonction de rappel sur chaque fd, seules les sockets actives appelleront activement le rappel, donc lorsqu'il y a moins de sockets actives, vous n'utilisez pas epoll Il y a le problème de baisse linéaire des performances des deux précédents, mais lorsque tous les sockets sont actifs, il peut y avoir des problèmes de performances.

3. Méthode de livraison des messages

select

Le noyau doit transmettre les messages à l'espace utilisateur, ce qui nécessite une action de copie du noyau

poll

Identique à ci-dessus

epoll

epoll est obtenu en partageant une mémoire entre le noyau et l'espace utilisateur de.

Résumé :

Pour résumer, lorsque vous choisissez select, poll ou epoll, vous devez tenir compte des occasions d'utilisation spécifiques et des caractéristiques de ces trois méthodes.

1. En apparence, epoll a les meilleures performances, mais lorsque le nombre de connexions est faible et que les connexions sont très actives, les performances de sélection et de sondage peuvent être meilleures que celles d'epoll. Après tout, le mécanisme de notification d'epoll nécessite de nombreuses fonctions. rappels.

2. Select est inefficace car il doit être interrogé à chaque fois. Mais l'inefficacité est aussi relative, selon la situation, elle peut aussi être améliorée grâce à une bonne conception

Apprentissage recommandé : Tutoriel vidéo Linux

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 de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Différence entre Centos et Ubuntu Différence entre Centos et Ubuntu Apr 14, 2025 pm 09:09 PM

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

Comment installer CentOS Comment installer CentOS Apr 14, 2025 pm 09:03 PM

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

Le choix de Centos après l'arrêt de l'entretien Le choix de Centos après l'arrêt de l'entretien Apr 14, 2025 pm 08:51 PM

CentOS a été interrompu, les alternatives comprennent: 1. Rocky Linux (meilleure compatibilité); 2. Almalinux (compatible avec CentOS); 3. Serveur Ubuntu (configuration requise); 4. Red Hat Enterprise Linux (version commerciale, licence payante); 5. Oracle Linux (compatible avec Centos et Rhel). Lors de la migration, les considérations sont: la compatibilité, la disponibilité, le soutien, le coût et le soutien communautaire.

Comment utiliser Docker Desktop Comment utiliser Docker Desktop Apr 15, 2025 am 11:45 AM

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Explication détaillée du principe docker Explication détaillée du principe docker Apr 14, 2025 pm 11:57 PM

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Que faire après Centos arrête la maintenance Que faire après Centos arrête la maintenance Apr 14, 2025 pm 08:48 PM

Une fois CentOS arrêté, les utilisateurs peuvent prendre les mesures suivantes pour y faire face: sélectionnez une distribution compatible: comme Almalinux, Rocky Linux et CentOS Stream. Migrez vers les distributions commerciales: telles que Red Hat Enterprise Linux, Oracle Linux. Passez à Centos 9 Stream: Rolling Distribution, fournissant les dernières technologies. Sélectionnez d'autres distributions Linux: comme Ubuntu, Debian. Évaluez d'autres options telles que les conteneurs, les machines virtuelles ou les plates-formes cloud.

Que faire si l'image Docker échoue Que faire si l'image Docker échoue Apr 15, 2025 am 11:21 AM

Dépannage des étapes pour la construction d'image Docker échouée: cochez la syntaxe Dockerfile et la version de dépendance. Vérifiez si le contexte de construction contient le code source et les dépendances requis. Affichez le journal de construction pour les détails d'erreur. Utilisez l'option - cibler pour créer une phase hiérarchique pour identifier les points de défaillance. Assurez-vous d'utiliser la dernière version de Docker Engine. Créez l'image avec --t [Image-Name]: Debug Mode pour déboguer le problème. Vérifiez l'espace disque et assurez-vous qu'il est suffisant. Désactivez SELINUX pour éviter les interférences avec le processus de construction. Demandez de l'aide aux plateformes communautaires, fournissez Dockerfiles et créez des descriptions de journaux pour des suggestions plus spécifiques.

Quelle configuration de l'ordinateur est requise pour VScode Quelle configuration de l'ordinateur est requise pour VScode Apr 15, 2025 pm 09:48 PM

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

See all articles