nl.phhsnews.com


nl.phhsnews.com / Hoe luisteren webservers naar nieuwe verzoeken?

Hoe luisteren webservers naar nieuwe verzoeken?


Wanneer u meer te weten komt over webservers en hoe ze werken, bent u misschien nieuwsgierig of ze voortdurend naar verzoeken luisteren of wachten totdat ze een aanvraag ontvangen verzoek om in actie te komen. Met dat in gedachten heeft de SuperUser Q & A-post van vandaag de antwoorden om de nieuwsgierigheid van een lezer te bevredigen.

De Question & Answer-sessie van vandaag komt tot ons dankzij SuperUser - een onderdeel van Stack Exchange, een door de gemeenschap gestuurde groep van Q & A-websites.

Screenshot met dank aan xmodulo / Linux Screenshots (Flickr).

De vraag

SuperUser-lezer user2202911 wil weten hoe webservers naar nieuwe aanvragen luisteren:

Ik probeer de details van 'dieper niveau' te begrijpen van hoe webservers werken. Ik wil weten of een server, bijvoorbeeld Apache, bijvoorbeeld continu peilt naar nieuwe aanvragen of dat deze werkt via een soort interrupt-systeem. Als het een interrupt is, wat vonk dan met de interrupt? Is het de netwerkkaartstuurprogramma?

Hoe luistert een webserver naar nieuwe aanvragen?

Het antwoord

SuperUser-bijdrager Greg Bowser heeft het antwoord voor ons:

Het korte antwoord is een soort interrupt-systeem . In wezen gebruiken ze I / O blokkeren, wat betekent dat ze slapen (blokkeren) tijdens het wachten op nieuwe gegevens.

  1. De server maakt een luisterende socket en blokkeert vervolgens tijdens het wachten op nieuwe verbindingen. Gedurende deze tijd zet de kernel het proces in een onderbreekbare slaap -status en voert andere processen uit. Dit is een belangrijk punt; het continu hebben van de procespolling zou CPU-bronnen verspillen. De kernel kan de systeembronnen efficiënter gebruiken door het proces te blokkeren totdat er werk voor is.
  2. Wanneer nieuwe gegevens op het netwerk aankomen, geeft de netwerkkaart een interruptie af.
  3. Zien dat er een onderbreken van de netwerkkaart leest de kernel via het stuurprogramma van de netwerkkaart de nieuwe gegevens van de netwerkkaart en slaat deze op in het geheugen. (Dit moet snel worden gedaan en wordt meestal afgehandeld binnen de interrupt handler.)
  4. De kernel verwerkt de nieuw binnengekomen data en associeert deze met een socket. Een proces dat op dat socket blokkeert, wordt gemarkeerd als ranable, wat betekent dat het nu kan worden uitgevoerd. Het hoeft niet noodzakelijkerwijs onmiddellijk te worden uitgevoerd (de kernel kan besluiten om nog andere processen uit te voeren).
  5. Op zijn gemak zal de kernel het geblokkeerde webserverproces ontwaken. (Aangezien het nu uitvoerbaar is.)
  6. Het webserverproces wordt voortgezet alsof er geen tijd verstreken is. De blokkerende systeemoproep wordt geretourneerd en alle nieuwe gegevens worden verwerkt. Ga vervolgens naar stap 1.

Heb je iets toe te voegen aan de uitleg? Geluid uit in de reacties. Wilt u meer antwoorden van andere technisch onderlegde Stack Exchange-gebruikers lezen? Bekijk hier de volledige discussiethread


Bepaalde applicaties voor gebruikers in Windows

Bepaalde applicaties voor gebruikers in Windows

Als u wilt beperken welke apps een gebruiker op een pc mag uitvoeren, biedt Windows u twee opties. U kunt de apps blokkeren waarvan u niet wilt dat een gebruiker deze uitvoert, of u kunt ze beperken tot het uitvoeren van specifieke apps. Zo gaat u het doen. GERELATEERD: Systeemherstel gebruiken in Windows 7, 8 en 10 OPMERKING: wees er absoluut zeker van dat u wijzigingen aanbrengt in een gebruikersaccount dat u eigenlijk wilt beperken, en dat je altijd een onbeperkt beheerdersaccount beschikbaar hebt om die wijzigingen ongedaan te maken.

(how-to)

Snel starten van een basishuls vanuit Windows 10's Verkenner

Snel starten van een basishuls vanuit Windows 10's Verkenner

Start Bash op Windows 10 en deze wordt automatisch geopend voor de thuismap van uw UNIX-account. In plaats van de opdracht cd te gebruiken om naar een andere map te gaan, kunt u Bash rechtstreeks vanuit een map in Verkenner starten. U kunt dit doen zonder register-hacks of wijzigingen. Het is gewoon verborgen.

(how-to)