Qual è la differenza tra il Locahost e l'indirizzo IP locale?
Se stai facendo un sacco di ritocchi di rete, configurazione di app e strumenti server basati su LAN, o semplicemente curiosi, probabilmente avrai notato che c'è una differenza tra l'host locale e l'indirizzo IP locale. Continua a leggere per imparare le differenze.
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 basato sulla comunità.
La domanda
Lettore SuperUser Diogo vuole sapere perché il comando ping tratta l'host locale e l'indirizzo IP locale in modo diverso quando, in superficie, sembrano essere la stessa cosa:
L'utilizzo di cmd e ping su Windows mi ha dato i seguenti risultati:
Pinging "localhost":
Pinging "192.168.0.10" (indirizzo IP locale):
Non sono entrambe le situazioni esattamente uguali?
Voglio dire, sto facendo il ping della stessa interfaccia, della stessa macchina e dello stesso indirizzo. Perché ottengo risultati così diversi?
Ovviamente c'è una differenza di qualche tipo, ma cosa sta succedendo esattamente quando si passa da uno all'altro?
La risposta
Il collaboratore di SuperUser Tom Wijsman offre le seguenti informazioni sulle sottili differenze tra i due:
Non stai facendo il ping della stessa interfaccia, senza alcuna interfaccia fisica hai ancora un "host locale".
Il tuo
localhost
è usato per riferirsi al tuo computer dal suo IP "interno", non da eventuali IP "esterni" del tuo computer. Quindi, i pacchetti ping non passano attraverso alcuna interfaccia di rete fisica; solo attraverso un'interfaccia loopback virtuale che invia direttamente i pacchetti da una porta all'altra senza alcun salto fisico.Potresti ancora chiedermi perché
localhost
sta risolvendo a:: 1
, mentre tradizionalmente ci aspettiamo che si risolva nell'indirizzo IPv4127.0.0.1
. Nota che.localhost
è tradizionalmente un TLD (vedi RFC 2606) che punta all'indietro all'indirizzo IP di loopback (per IPv4, vedere RFC 3330, specialmente 127.0.0.0/8).Alzando lo sguardo
localhost
utilizzandonslookup
ci da:
nslookup localhost
... Nome: localhost Indirizzi: :: 1 127.0.0.1
Pertanto Windows preferisce utilizzare l'indirizzo IP di loop back IPv6
:: 1
(vedi RFC 2373) come è elencato per primo.Ok, quindi, da dove proviene, diamo un'occhiata al file hosts.
digitare% WINDIR% \ System32 \ Drivers \ Etc \ Host
... # La risoluzione dei nomi localhost viene gestita all'interno del DNS stesso. # 127.0.0.1 localhost # :: 1 localhost ...
Hmm, dobbiamo guardare le impostazioni DNS di Windows.
Questo articolo della Knowledge Base ci parla di un'impostazione che influisce su ciò che Windows preferisce, enfatizzato in grassetto:
- Nell'editor del Registro di sistema, individuare e quindi fare clic sulla seguente sottochiave del Registro di sistema:
HKEY_LOCAL_MACHINE \ SYSTEM \ CurrentControlSet \ Services \ Tcpip6 \ Parameters
- Fare doppio clic su DisabledComponents per modificare la voce DisabledComponents. Nota: se la voce DisabledComponents non è disponibile, è necessario crearla. Per effettuare questa operazione, attenersi alla seguente procedura:
- Nel menu Modifica, scegliere Nuovo, quindi fare clic su Valore DWORD (32 bit).
- Digitare DisabledComponents e quindi premere INVIO.
- Fare doppio clic su DisabledComponents.
- Digitare uno dei seguenti valori nel campo Dati valore: per configurare il protocollo IPv6 allo stato desiderato, quindi fare clic su OK:
- genere
0
per abilitare tutti i componenti IPv6. (Impostazione predefinita di Windows)- genere
0xffffffff
per disabilitare tutti i componenti IPv6, ad eccezione dell'interfaccia di loopback IPv6. Questo valore configura anche Windows per preferire l'utilizzo di Protocollo Internet versione 4 (IPv4) su IPv6 modificando le voci nella tabella dei criteri del prefisso. Per ulteriori informazioni, vedere Selezione indirizzo di origine e destinazione.- genere
0x20
preferire IPv4 su IPv6 modificando le voci nella tabella delle politiche del prefisso.- genere
0x10
disabilitare IPv6 su tutte le interfacce non tunnel (su interfacce LAN e PPP [Point-to-Point Protocol]).- genere
0x01
disabilitare IPv6 su tutte le interfacce tunnel. Questi includono Protocollo di indirizzamento automatico del tunnel (ISATAP) in-sito, 6to4 e Teredo.- genere
0x11
per disabilitare tutte le interfacce IPv6 tranne l'interfaccia di loopback IPv6.- Riavvia il computer affinché questa impostazione abbia effetto.
Cos'è questa tabella delle politiche dei prefissi?
netsh interface ipv6 show prefixpolicies
(oprefixpolicy
sulle versioni precedenti)Prefisso dell'etichetta di precedenza ---------- ----- -------------------------------- 50 0 :: 1/128 45 13 fc00 :: / 7 40 1 :: / 0 10 4 :: ffff: 0: 0/96 7 14 2002 :: / 16 5 5 2001 :: / 32 1 11 fec0 :: / 10 1 12 3ffe :: / 16 1 10 :: / 96
Questa tabella decide quali prefissi hanno la precedenza su altri prefissi durante le risoluzioni DNS.
Ah, quindi usando quel KB potremmo aggiungere voci che denotano che IPv4 ha una precedenza più alta di IPv6.
Nota: Non c'è motivo di ignorare questo comportamento, a meno che non si verifichino problemi compatibili. La modifica di questa impostazione sul nostro server Windows ha rotto il nostro server di posta, quindi dovrebbe essere gestito con cura ...
Non c'è niente che ci piaccia più di una risposta esauriente e informativa con i documenti di supporto collegati da risparmiare. Chiaramente l'host locale e l'indirizzo IP locale sono entità distinte, servono a scopi diversi e ora sappiamo tutti perché.
Hai qualcosa da aggiungere alla spiegazione? Sound off nei commenti. Vuoi leggere più risposte dagli altri utenti di Stack Exchange esperti di tecnologia? Controlla la discussione completa qui.