
Quando si imparano i server Web e come funzionano, si può essere curiosi di ascoltare costantemente le richieste o attendere fino a quando non ricevono un richiesta di entrare in azione. Con questo in mente, il post di Q & A di SuperUser di oggi ha le risposte per soddisfare la curiosità di un lettore.
La sessione di domande e risposte di oggi ci viene fornita per gentile concessione di SuperUser, una suddivisione di Stack Exchange, un raggruppamento di siti Web di domande e risposte.
Schermata per gentile concessione di xmodulo / Linux Screenshots (Flickr).
Il lettore SuperUser user2202911 vuole sapere come i server web ascoltano nuove richieste:
Sto cercando di capire i dettagli di "livello più profondo" come funzionano i server web. Voglio sapere se un server, per esempio, Apache, sta continuamente interrogando per nuove richieste o se funziona con una sorta di sistema di interrupt. Se si tratta di un'interruzione, che cosa sta provocando l'interruzione? È il driver della scheda di rete?
In che modo un server web ascolta le nuove richieste?
Il collaboratore SuperUser Greg Bowser ha la risposta per noi:
La risposta breve è una sorta di sistema di interruzione . Essenzialmente, usano l'I / O di blocco, il che significa che dormono (bloccano) mentre aspettano nuovi dati.
- Il server crea un socket di ascolto e poi blocca in attesa di nuove connessioni. Durante questo tempo, il kernel mette il processo in uno stato interrompibile sleep e esegue altri processi. Questo è un punto importante; avere il processo di polling continuo sprecherebbe risorse della CPU. Il kernel è in grado di utilizzare le risorse di sistema in modo più efficiente bloccando il processo fino a quando non c'è lavoro per farlo.
- Quando arrivano nuovi dati sulla rete, la scheda di rete emette un interrupt.
- Vedendo che c'è un interrompendo dalla scheda di rete, il kernel, tramite il driver della scheda di rete, legge i nuovi dati dalla scheda di rete e li archivia in memoria. (Questo deve essere fatto rapidamente e generalmente viene gestito all'interno del gestore di interrupt.)
- Il kernel elabora i dati appena arrivati e li associa con un socket. Un processo che sta bloccando su quel socket verrà contrassegnato come eseguibile, il che significa che ora è idoneo per essere eseguito. Non viene necessariamente eseguito immediatamente (il kernel potrebbe decidere di eseguire altri processi ancora).
- A suo piacimento, il kernel riattiverà il processo del server Web bloccato. (Poiché ora è eseguibile.)
- Il processo del server Web continua ad essere eseguito come se non fosse trascorso il tempo. La sua chiamata di sistema di blocco ritorna e elabora qualsiasi nuovo dato. Quindi vai al passaggio 1.
Hai qualcosa da aggiungere alla spiegazione? Audio disattivato nei commenti. Vuoi leggere più risposte dagli altri utenti di Stack Exchange esperti di tecnologia? Controlla il thread completo di discussione qui.
Principiante: come mantenere, archiviare e eseguire il backup dei dati in Outlook 2013
Oggi, stiamo trattando il noioso argomento di Outlook. Manutenzione e sicurezza, come in, mantenimento e protezione del file di dati di Outlook 2013 - completo di tutti i tuoi dati importanti - eseguendo il backup e archiviandolo. Fino ad ora, se hai utilizzato Outlook per comporre e inviare e -Mail, e hai avuto il tempo di importare i tuoi contatti G-mail nella tua rubrica, o il fatto che stai anche utilizzando una rubrica di Outlook, significa che hai un sacco di dati che devono essere protetti.
Google Cardboard è bello. È un modo per provare la realtà virtuale con un auricolare economico in cartone e il tuo attuale telefono o iPhone Android. Ma, rispetto a dispositivi come Oculus Rift, Google Cardboard è solo un trucco da salotto. Non vogliamo fare di tutto per sbattere Google Cardboard. Di nuovo, è pulito.