Tuesday, 4 February 2020

windows - Why is "127.0.0.1 localhost" needed in HOSTS file?



I disabled all my network connections and deleted 127.0.0.1 localhost in HOSTS file but cannot find what had I broken by it. My IIS and MS SQL Server 2008 R2 continues to resolve localhost just fine


Why does HOSTS file always contain 127.0.0.1 localhost ?
What had I broken by deleting this entry?


I am on Windows XP Pro SP3 writing here still without localhost in HOSTS file.
Should I put it back and how fast ?




The reasons of interest are many fold - for instance:





------ UPDATE05:


I am not changing the question! I add updates. Can I ask to stop deleting and editing it until I write that I fished with it? For ex., just now I wrote the same comment in all posts addressing the same point.


This is the essence of my question/doubt - that the DNS does not make any sense in relation to "localhost" or "127.0.0.222" or "(local)" names, synonyms, aliases, links, addresses, IDs, tokens, whatever.


They are hundreds synonyms to the same entity and they are internal and Windows-es know it without any resolutions since there is no sense to resolve between so many synonyms!


They are related to internal computer mechanisms while DNS is external (between various computers). How can internal IDs can depend on external ones?


All Windowses (including Home Editions) will have internal DNS server in order to function? and then replicate it when/if connected to network?


Well, the link from comments did not appear in Linked section, as I was told.


I forked a child subquestion:
https://stackoverflow.com/questions/3536351/is-localhost-host-resolved-to-127-0-0-1



Answer



The hosts file just associates canonical or fully qualified names to IP addresses.


For instance, I could have:


127.0.0.1  moes-bar-and-grill

Then anything connecting to moes-bar-and-grill would establish a connection to the loopback device, aka 127.0.0.1, commonly resolved as localhost.


I could also have (and this is quite common)


127.0.0.1  annoying-ad-server.com

Applications continue to work because they will connect to 127.0.0.1 (which is still a configured / up interface) if localhost does not resolve.


I'm not sure why you would want to disable the loopback address, but simply taking localhost out of your host file is not going to do that.


Edit


Well written software will make more than one attempt at resolving anything (resolving in a sense of working around problems, no pun intended) before it just dies and in some cases will continue to function even if things are not as expected. That does not mean that the software will work as advertised, it only means that it was written by a very defensive programmer.


Very defensive does not always mean helpful when it comes to telling the user that serious problems exist, for instance localhost not resolving. I can write stuff that passes tests no matter what a user does to their system, but that does nothing to promote the cause of "This won't work!". There is a stark difference between it runs and it works and you will only explore the difference between the two over time with every program that you run.


While everything seems to work, now, I think you may be headed for trouble later.


Disclaimer: I write software for a living.


No comments:

Post a Comment

How can I VLOOKUP in multiple Excel documents?

I am trying to VLOOKUP reference data with around 400 seperate Excel files. Is it possible to do this in a quick way rather than doing it m...