Lorsque vous découvrez les serveurs Web et leur fonctionnement, vous pouvez être curieux de savoir s'ils sont constamment à l'écoute des demandes ou s'ils attendent demande d'entrer en action. Dans cette optique, le poste de questions / réponses SuperUser d'aujourd'hui a les réponses pour satisfaire la curiosité d'un lecteur.
La séance de questions et réponses d'aujourd'hui nous est offerte par SuperUser, une subdivision de Stack Exchange, un regroupement communautaire de sites Web Q & A.
Capture d'écran avec la permission de xmodulo / Screenshots de Linux (Flickr).
SuperUser reader user2202911 veut savoir comment les serveurs web écoutent les nouvelles requêtes:
J'essaie de comprendre les détails du "niveau plus profond" comment fonctionnent les serveurs web. Je veux savoir si un serveur, par exemple Apache, interroge continuellement de nouvelles requêtes ou s'il fonctionne avec un système d'interruption quelconque. 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?
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 peut utiliser plus efficacement les ressources du système 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 un interrompre à partir 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'interruption.)
- 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 forcément 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. Ensuite, passez à 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.
HDTV Overscan: Qu'est-ce que c'est et pourquoi vous devriez (probablement) le désactiver
Voici quelque chose que vous ne savez peut-être pas: la TVHD que vous aimez ne montre probablement pas toute l'image sur son écran. En fait, jusqu'à cinq pour cent de l'image peuvent être coupés sur les bords - cela s'appelle overscan . C'est l'ancienne technologie des téléviseurs CRT (à tube cathodique) d'antan.
Comment utiliser les nouveaux Google Hangouts dans votre navigateur
Les jours de brouillage dans Gmail avec un tas de plugins différents pour quatre navigateurs différents sont terminés, car Google a finalement enlevé le voile leur toute nouvelle plate-forme Google Hangouts basée sur un navigateur. L'application de messagerie s'est avérée très populaire auprès de l'ensemble professionnel, offrant un moyen rapide et simple pour entrer en contact avec tous vos contacts e-mail en un instant.