de.phhsnews.com


de.phhsnews.com / Wie hören Webserver auf neue Anfragen?

Wie hören Webserver auf neue Anfragen?


Wenn Sie sich über Webserver und ihre Funktionsweise informieren, sind Sie vielleicht neugierig, ob sie ständig auf Anfragen warten oder warten, bis sie eine empfangen Aufforderung, in Aktion zu treten. Vor diesem Hintergrund hat der heutige SuperUser-Q & A-Beitrag Antworten auf die Neugier eines Lesers.

Die heutige Question & Answer-Sitzung kommt uns dank SuperUser - einer Unterteilung von Stack Exchange, einer Community-gesteuerten Gruppierung von Q & A-Websites -

Screenshot mit freundlicher Genehmigung von xmodulo / Linux Screenshots (Flickr).

Die Frage

SuperUser reader user2202911 möchte wissen, wie Webserver auf neue Anfragen warten:

Ich versuche die Details der 'tieferen Ebene' zu verstehen Wie funktionieren Webserver? Ich möchte wissen, ob ein Server, sagen wir zum Beispiel Apache, ständig nach neuen Anfragen fragt oder ob es durch ein Interrupt-System funktioniert. Wenn es ein Interrupt ist, was löst den Interrupt aus? Ist es der Netzwerkkartentreiber?

Wie hört ein Webserver auf neue Anfragen?

Der Antwort

SuperUser-Mitarbeiter Greg Bowser hat die Antwort für uns:

Die kurze Antwort ist eine Art Interrupt-System . Im Wesentlichen verwenden sie blockierende E / A, dh sie schlafen (blockieren), während sie auf neue Daten warten.

  1. Der Server erstellt einen abhörenden Socket und blockiert dann, während er auf neue Verbindungen wartet. Während dieser Zeit versetzt der Kernel den Prozess in einen unterbrechbaren Ruhezustand und führt andere Prozesse aus. Dies ist ein wichtiger Punkt; Wenn die Prozessabfrage kontinuierlich läuft, würden CPU-Ressourcen verschwendet werden. Der Kernel ist in der Lage, die Systemressourcen effizienter zu nutzen, indem er den Prozess so lange blockiert, bis es Arbeit gibt.
  2. Wenn neue Daten im Netzwerk ankommen, gibt die Netzwerkkarte einen Interrupt aus.
  3. Es wird ein Interrupt von der Netzwerkkarte liest der Kernel über den Netzwerkkartentreiber die neuen Daten von der Netzwerkkarte und speichert sie im Speicher. (Dies muss schnell erledigt werden und wird im Allgemeinen innerhalb des Interrupt-Handlers abgewickelt.)
  4. Der Kernel verarbeitet die neu angekommenen Daten und ordnet sie einem Socket zu. Ein Prozess, der für diesen Socket blockiert wird, wird als runnable markiert, was bedeutet, dass er jetzt ausgeführt werden kann. Es läuft nicht unbedingt sofort (der Kernel kann sich entscheiden, andere Prozesse noch auszuführen).
  5. Der Kernel wird den blockierten Web-Server-Prozess aktivieren. (Da es jetzt ausführbar ist.)
  6. Der Webserverprozess wird so ausgeführt, als wäre keine Zeit vergangen. Der blockierende Systemaufruf kehrt zurück und verarbeitet neue Daten. Fahren Sie dann mit Schritt 1 fort.

Haben Sie etwas zur Erklärung hinzuzufügen? Ton in den Kommentaren ab. Möchten Sie mehr Antworten von anderen technisch versierten Stack Exchange Benutzern lesen? Sehen Sie sich den vollständigen Diskussionsfaden hier an.


So beheben Sie die Textweiterleitung auf Ihrem iPad oder Mac (wenn es nicht funktioniert)

So beheben Sie die Textweiterleitung auf Ihrem iPad oder Mac (wenn es nicht funktioniert)

Wir haben bereits beschrieben, wie Sie die Textweiterleitung von Ihrem iPhone auf iPad oder Mac einrichten. Es ist ein großartiges Feature, obwohl wir später erkannt haben, dass es nicht wie erwartet funktioniert. Glücklicherweise gibt es eine schnelle Lösung, die Sie verwenden können, um es richtig in Gang zu setzen.

(how-to)

Schnellste Möglichkeit, eine große Anzahl von Fotos zu Hause zu scannen

Schnellste Möglichkeit, eine große Anzahl von Fotos zu Hause zu scannen

Mein Vater hat kürzlich beschlossen, all unsere Baby- und Kindheitsfotos mit seinem HP Flachbettscanner zu Hause zu scannen und schnell erkannt, dass es Jahre dauern würde, alle Fotos in den Computer zu scannen, wenn er es einzeln macht. Dann suchte er nach teureren Geräten, die mehr Fotos gleichzeitig und schneller scannen konnten.Es

(How-to)