
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.
Comment partager des photos Apple Live avec tout le monde
Live Photos est une innovation astucieuse récemment introduite par Apple 9 dans iOS 9, permettant aux utilisateurs de réaliser de courtes vidéos sous forme de photos. Malheureusement, la seule façon de les partager facilement est avec d'autres utilisateurs de l'iPhone. Voici comment les partager avec tout le monde.
Comment utiliser votre Roku Comme un Chromecast
Chromecast de Google vous permet de lancer des vidéos et de les contrôler à partir de votre téléphone, de diffuser tout votre écran sur votre téléviseur et d'utiliser généralement un smartphone au lieu d'un éloigné. Commencez à regarder Netflix ou YouTube à partir de votre téléphone ou de votre navigateur Web Le Roku prend en charge DIAL-short pour le protocole "Discovery and Launch" développé conjointement par Netflix et Youtube.