Why is "127.0.0.1 localhost" needed in HOSTS file?

66,189

Solution 1

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.

Solution 2

The hosts file is a mapping between the IP address and the host name so that when you type the host name it resolves to the specified address.

By removing the line you are stopping Windows taking "localhost" and mapping it to "127.0.0.1".

I can think of two reasons why you are seeing it "work".

  1. You haven't rebooted the machine so the mapping is still in memory.
  2. The applications you've tried it in do the mapping for you.

As long as #2 applies you don't need it, but were you to use an application that didn't do the mapping for you it would fail.

So, on balance, you should put the line back. However, you don't have to do it as a matter of urgency.

Share:
66,189

Related videos on Youtube

Gennady Vanin Геннадий Ванин
Author by

Gennady Vanin Геннадий Ванин

Business Analyst, ex- programmer, biz analyst, Q&A developer in Test, chemical cybernetics engineer, scientist, US patent attorney, translator, tourist guide, traveller, parachuter, tennis player, futebolista, military officer etc.

Updated on September 17, 2022

Comments

  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 2 years

    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

    • Tim Post
      Tim Post almost 14 years
      If you do something that results in something else breaking, it's generally a good idea to undo whatever you did :) Removing the host association to localhost will probably break things, even if nothing (yet) seems obviously broken. Note : Removing the entry in hosts doesn't take down the interface, it just breaks localhost resolving to that interface.
    • JJ_Australia
      JJ_Australia almost 14 years
      -1 for unnecessary profanities.
    • Tim Post
      Tim Post almost 14 years
      Do you have anything else to say, @vgv8 ? Two people answered your original question. Please don't get mad at us for not sitting here for hours refreshing this page just in case you make an edit so we can immediately revise our answer.
    • Gnoupi
      Gnoupi almost 14 years
      Related questions (according to the OP): superuser.com/questions/178187/… and superuser.com/questions/178279/…
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Tim, I always have a lot to say but to be heard I need to formulate it first! Plz do not refresh, THIS IS NOT CHAT! There are various reasons why I can return late, for ex., because we have 12 hours difference between us. I need to think, to read, to sleep it over
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Tim, thanks! My updates reflecting your concerns and attention/inteerest to my question were updated by me and deleted by superior members but you still can see remnants in the "Linked" section to the right of this page or in revisions of main post
    • Gnoupi
      Gnoupi almost 14 years
      @vgv8 - Tim's point is that people answering won't get notified by your question updates unless they "favorite" it. The correct way to add details related to one of the answers given is to comment under this answer. If you added a lot of details which can benefit other answers, then editing the question is the good way to go, but note that you should put a "I have updated my question with more details regarding to what you said" comment under their answer, so they get notified about it.
    • Christoph Rüegg
      Christoph Rüegg almost 14 years
      Stop changing the question. This is not a chatroom.
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Gnoupi, thanks, your comment was the most important comment I ever had in trilogy. Can others see revisions for what had been deleted in main post? Once more deleted links appear in the section "Linked" in the right sidebar. Do others also see them? Or I add them into comments
    • Gnoupi
      Gnoupi almost 14 years
      @vgv8 - it's enough to put a link in the comments, or an answer, for it to appear on the "linked" category, on side. Revisions are visible for everyone, by clicking the "edited xxminutes ago" link. I haven't fully followed concerns about you, but from your question, I recommend two things: keep it clear, so that people can read and understand them, and don't change the topic to another question. If another question pops in your mind, you can ask a new one, separately.
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Gnoupi, thanks. I shall post new questions (to get more downvotes UNTIL the button "ADD COMMENTS" disappear and one more suspension). I NEVER change - I add updates (or make corrections of slips in bold or noted as changed
    • Gnoupi
      Gnoupi almost 14 years
      @vgv8 - people don't downvote without a reason. You have to balance the updates you make with the fact of keeping a clear question. A question with two pages of "updates" is impossible to read, and gets downvoted for not being clear.
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Gnoupi. certainly! I am grateful! The negative response always draws more attention and people, who, eventually, can answer or add relevant helpful info.
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Tim, plz note that Linked posts are different from the links given in my main post
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @ALL-ALL-ALL, See my answer! One more VICTORY OF ABSTRACT REASONING
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
      @Hello71, u r on my list of spammers. Plz do not write in my posts, I shall ignore your writings
    • Gennady Vanin Геннадий Ванин
      Gennady Vanin Геннадий Ванин almost 14 years
    • Gnoupi
      Gnoupi almost 14 years
      @vgv8 these sites are not about the people. Don't hold personal grudges against other users, care only about the individual content.
    • Gnoupi
      Gnoupi almost 14 years
      @vgv8 - the links in the "linked" column are appearing only if it's from Super User. Also, please stop editing your question for no reason. You had your answer, you marked it as accepted, stop splitting hairs. If you have another question, ask it in another one. It should be only one question per "question". It seems obvious when said, but it's apparently not obvious enough.
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    That's why the colleagues are for! If I reboot and it stops, then, I shall need to reboot again. I'm rebooting once per day (when go to sleep and get up at morning), if not more rare, so it would take me 2+ days to see if I shall not forget about this issue on the way. I tried to enable/disable network connections, various caches but evreything seems to continue working for me.
  • Tamara Wijsman
    Tamara Wijsman almost 14 years
    @vgv8: Executing ipconfig /displaydns | findstr /C:localhost will show you that it is still in the cache. Executing ipconfig /flushdns will force a flush of the cache. If you won't, it will happen when the TTL expires. The default TTL is 86400 seconds, so after a day the localhost entry will expire and thus will not resolve anymore...
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @ Tim Post, Unfortunately, I do not have reputation to upvote your answer(it requires 15). Only marked it as answer though I have doubts/comments that, I believe, deserve NOT to be lost in comments
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    Ok, i've got ability to upvote by accepting your answer. +1, it is pity that correct answers are frequently undervoted
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @Tim Post, I added my answer. Does it make sense to you?
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @TonyWij, I also wrote that localhost as well as 127.0.0.222 work with all network connections disabled as well as without network cards inserted in my computer at all. Which internal DNS on Windows XP?
  • Tim Post
    Tim Post almost 14 years
    That is great for the services you listed, but what breaks? I know you can't possibly have installed everything that dies if 'localhost' can't be resolved. I still don't quite understand why you wanted to get rid of it anyway? Maybe I'm just dense, I just want to give you a good answer.
  • Tim Post
    Tim Post almost 14 years
    @vgv8 - I've updated my answer.
  • Tamara Wijsman
    Tamara Wijsman almost 14 years
    @vg8 You didn't state the DNS cache specific so that's why I thought about suggesting it to you, as there the localhost entry can be found if it's in the HOSTS file. Disabling or removing all connections doesn't cause the internal network features of Windows to stop functioning... You would have to disable the DNS Client service for this, which I wouldn't suggest as this is a huge impact on surfing. (As the caching stops working...)
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @TomWij, 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, as they are related to internal computer mechanism while DNS is external (between various computers). I believe that I stated all (though it is transparent) but they were deleted. Is it possible to lock posts from editing until the lock is removed by author?
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    The doubt is universal and conceptual WTF local names and their synonyms have to do with DNS? It is not comprehensible conceptually - if I unplug network the computer will stop working or shall all Windows head to having internal DNS server?
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @Tim, see my comments to other answers. I cannot get WTF internal computer mechanisms (and their labels, synonyms, IDs, addresses, links, whatever you may call them, for internal use) can depend on external ones (DNS)?
  • Tamara Wijsman
    Tamara Wijsman almost 14 years
    Locking is not possible, the complete history of posts can be viewed. Comments can also be removed without notice, but as far as I followed this question that didn't happen so far... As for DNS: Domain Resolving happens on your computer first with the HOSTS file and the DNS Client Cache, if the name can't be resolved there it will make a request to a DNS server. Your browser or SQL server might be written to automatically resolve localhost to 127.0.0.1 before the DNS stuff is even touched, but not every application will be able to do so... As Tim Post said.
  • Tamara Wijsman
    Tamara Wijsman almost 14 years
    Check my comment on ChrisF his answer. If you unplug the network the only thing that will stop functioning are the request to an external DNS server and external computers; thus the HOSTS file, DNS Client Cache and internal network services will remain functional.
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @moderator, I cannot submit (or edit) posts in SU, MSU, SO though I did not submit any questions for 24 hours (and I am banned from all other sites). How can I communicate to resolve this issue?
  • Tamara Wijsman
    Tamara Wijsman almost 14 years
    @vgv8: See my comment on superuser.com/questions/178706/…
  • Gennady Vanin Геннадий Ванин
    Gennady Vanin Геннадий Ванин almost 14 years
    @TomWij, thanks, see my comment to your comment there (I cannot post in MSU with the same issue and I am banned from MSO and MSF)