HOSTS file being ignored
My (Windows XP, Professional, v2002, SP3) workstation is completely ignoring my hosts file.
Here is the code in my hosts file:
127.0.0.1 localhost
172.17.1.107 wiki
But, when I open a browser and type "wiki" in the URL bar and hit "Enter" it takes me to the old location of my wiki as it appeared in my old hosts file:
10.0.36.100 wiki
Even though I have renamed the old hosts file "hosts_full" and moved it to my desktop (so, out of the etc folder entirely).
I have so far taken the following steps:
- Restarted (3 times)
- Ran
ipconfig /flushdns
from the command line - Ran
ping wiki
from the command line, response was
Reply from 10.0.36.100: bytes=32 time=1ms TTL=63
I've cleared every cache I can think of (IE, FF).
I have an ISA firewall client that runs on my machine and I've tried all of this with it disabled and enabled. In fact, the firewall uses the old hosts file to resolve itself:
10.0.2.126 isa3
And somehow it still works fine even though the new hosts file doesn't contain that line.
Any ideas??? Thanks in advance for the help!
Any chance you are using a proxy server for browsing? If so it might be that the proxy server is resolving the dns name for you.
And thats why you get different results in a commandline with ping as opposed to the browser.
Off chance traffic is intercepted and changed. Very off chance...
Firewall Responding To Pings?
This is a long shot from the ip address you gave, but what happens when you ping the new ip directly, does that work?
The reason I ask, if 10.0.36.100 happens to be a firewall that responds to the ping, it will say reply from that, even though you were pinging a different IP....
Big Hosts File?
Also, this got me and another IT person once, there were lots of blank lines in the window hosts files, and then entries way down below -- we didn't noticed the scroll bar :-)
Is the hosts file really the hosts file?
Lastly, look in the registry and make sure the host file is where you think it is, the following key specifies where the actual hosts file is:
\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\DataBasePath
Try to flush your DNS Cache with Start -> Run...
ipconfig /flushdns
Also try to deactivate NetBIOS and LMHOSTS for your Network Adapter. You can change the settings in the TCP/IP Properties of the used Network Connection, under Advanced -> WINS.
Turns out that my corporate DNS was being hit before my hosts file. So I:
- Opened my TCP/IP Properties (Control Panel > Network Connections > Local Area Connection > Properties > (scroll down) Internet Protocol (TCP/IP) > Properties.
- Clicked "Use the following DNS server addresses:" (Instead of Obtain DNS server address automatically)
- entered "172.0.0.1" and "172.0.0.2" (and clicked ok)
Now my hosts file works just fine... From the command line. However, if I put an entry in for www.google.com that points to 172.17.1.107, when I ping it from the command line, it returns from the IP address I specified in the hosts file. But if I hit it from the browser, it still shows me Google instead of my local site. But if I put an entry in for "fredspc" that points to 172.17.1.107 and hit that from the browser, it takes me to 172.17.1.107.
I figured this out because if I entered "tedspc" in my hosts file (i.e. something that would never resolve) and gave it an IP address and pinged it, it would resolve to that IP address. The problem was that www.wiki.com and anything else I was entering into my hosts file had an entry in my corporate DNS server, which was causing it to resolve, which meant it never looked at my hosts file (because the corporate DNS server gets looked at first before the hosts file). So I've cut the corporate DNS out of the command prompt loop, but not out of the browser loop I guess... Any ideas?
According to http://technet.microsoft.com/en-us/library/bb727005.aspx it could be in your local NETBIOS name cache. You can use nbtstat to query/purge this cache.
nbtstat /c
shows the cached entries which can be cleared with
nbtstat /R