29Jul
Lorsque vous découvrez les serveurs Web et leur fonctionnement, vous pouvez être curieux s'ils sont constamment à l'écoute des demandes ou s'ils attendent de recevoir une demande d'intervention. Dans cet esprit, le SuperUser Q & A post d'aujourd'hui a les réponses pour satisfaire la curiosité d'un lecteur.
Question d'aujourd'hui &La session de réponse nous est offerte par SuperUser, une subdivision de Stack Exchange, un regroupement communautaire de sites Web Q & A.
Image reproduite avec l'aimable autorisation de xmodulo / Screenshots de Linux( Flickr).
La question
SuperUser lecteur user2202911 veut savoir comment les serveurs web écoutent les nouvelles requêtes:
J'essaie de comprendre les détails du 'niveau plus profond' du fonctionnement des serveurs web. Je veux savoir si un serveur, par exemple Apache, interroge continuellement de nouvelles requêtes ou s'il fonctionne par une sorte de système d'interruption. Si c'est une interruption, qu'est-ce qui déclenche l'interruption? Est-ce le pilote de la carte réseau?
Comment un serveur web écoute-t-il les nouvelles demandes?
La réponse
SuperUser contributeur Greg Bowser a la réponse pour nous:
La réponse courte est une sorte de système d'interruption. Essentiellement, ils utilisent des E / S bloquantes, ce qui signifie qu'ils dorment( bloquent) en attendant de nouvelles données.
- Le serveur crée un socket d'écoute puis bloque en attendant de nouvelles connexions. Pendant ce temps, le noyau met le processus dans un état de sommeil interruptible et exécute d'autres processus. C'est un point important;avoir le processus polluer en permanence gaspillerait les ressources du processeur. Le noyau est capable d'utiliser les ressources du système plus efficacement en bloquant le processus jusqu'à ce qu'il y ait du travail à faire.
- Lorsque de nouvelles données arrivent sur le réseau, la carte réseau émet une interruption.
- Voyant qu'il y a une interruption de la carte réseau, le noyau, via le pilote de la carte réseau, lit les nouvelles données de la carte réseau et les stocke en mémoire.(Cela doit être fait rapidement et est généralement traité dans le gestionnaire d'interruptions.)
- Le noyau traite les données nouvellement arrivées et les associe à un socket. Un processus qui bloque sur ce socket sera marqué runnable, ce qui signifie qu'il est maintenant éligible à s'exécuter. Il ne fonctionne pas nécessairement immédiatement( le noyau peut décider d'exécuter d'autres processus).
- À loisir, le noyau réveillera le processus du serveur web bloqué.(Comme il est maintenant exécutable.)
- Le processus du serveur Web continue à s'exécuter comme si aucun temps ne s'était écoulé.Son appel système bloquant renvoie et traite toutes les nouvelles données. Passez ensuite à l'étape 1.
Avez-vous quelque chose à ajouter à l'explication? Sonnez dans les commentaires. Vous voulez lire plus de réponses d'autres utilisateurs de Stack Exchange? Découvrez le fil de discussion complet ici.