Hosts (file) explained

The computer file hosts is an operating system file that maps hostnames to IP addresses. It is a plain text file. Originally a file named HOSTS.TXT was manually maintained and made available via file sharing by Stanford Research Institute for the ARPANET membership, containing the hostnames and address of hosts as contributed for inclusion by member organizations. The Domain Name System, first described in 1983 and implemented in 1984,[1] automated the publication process and provided instantaneous and dynamic hostname resolution in the rapidly growing network. In modern operating systems, the hosts file remains an alternative name resolution mechanism, configurable often as part of facilities such as the Name Service Switch as either the primary method or as a fallback method.

Purpose

The hosts file is one of several system facilities that assists in addressing network nodes in a computer network. It is a common part of an operating system's Internet Protocol (IP) implementation, and serves the function of translating human-friendly hostnames into numeric protocol addresses, called IP addresses, that identify and locate a host in an IP network.

In some operating systems, the contents of the hosts file is used preferentially to other name resolution methods, such as the Domain Name System (DNS), but many systems implement name service switches, e.g., nsswitch.conf for Linux and Unix, to provide customization. Unlike remote DNS resolvers, the hosts file is under the direct control of the local computer's administrator.[2]

File content

The hosts file contains lines of text consisting of an IP address in the first text field followed by one or more host names.[3] The host names map to the IPs, not vice versa. Each field is separated by white space – tabs are often preferred for historical reasons, but spaces are also used. Comment lines may be included; they are indicated by an octothorpe (#) in the first position of such lines. Entirely blank lines in the file are ignored.[4] For example, a typical hosts file may contain the following: 127.0.0.1 localhost loopback ::1 localhostThis example only contains entries for the loopback addresses of the system and their host names, a typical default content of the hosts file. The example illustrates that an IP address may have multiple host names (localhost and loopback), and that a host name may be mapped to both IPv4 and IPv6 IP addresses, as shown on the first and second lines respectively.

Location in the file system

The location of the hosts file in the file system hierarchy varies by operating system. It is usually named hosts, without an extension.

Operating SystemVersion(s)Location
Unix, Unix-like, POSIX/etc/hosts[5]
Microsoft Windows3.1%WinDir%\HOSTS
95, 98, ME%WinDir%\hosts[6]
NT, 2000, XP,[7] 2003, Vista,
2008, 7, 2012, 8, 10, 11
%SystemRoot%\System32\drivers\etc\hosts[8]
Windows Mobile, Windows PhoneRegistry key under HKEY_LOCAL_MACHINE\Comm\Tcpip\Hosts
Apple Macintosh9 and earlierPreferences or System folder
Mac OS X 10.0–10.1.5[9] (Added through NetInfo or niload)
Mac OS X 10.2 and newer/etc/hosts (a symbolic link to /private/etc/hosts)
Novell NetWareSYS:\hosts
OS/2, eComStation, ArcaOS"bootdrive":\mptn\\
SymbianSymbian OS 6.1–9.0C:\system\data\hosts
Symbian OS 9.1+C:\private\10000882\hosts
MorphOSNetStackENVARC:sys/net/hosts
AmigaOS< 4AmiTCP:db/hosts
4DEVS:Internet/hosts
AROSENVARC:AROSTCP/db/hosts
Android/etc/hosts (a symbolic link to /system/etc/hosts)
iOSiOS 2.0 and newer/etc/hosts (a symbolic link to /private/etc/hosts)
TOPS-20SYSTEM:HOSTS.TXT
Plan 9/lib/ndb/hosts
BeOS/boot/beos/etc/hosts[10]
Haiku/system/settings/network/hosts[11]
OpenVMSUCXUCX$HOST
TCPwareTCPIP$HOST
RISC OS3.7, 5!Boot.Resources.Internet.files.Hosts
later boot sequence!Boot.Choices.Hardware.Disabled.Internet.Files.Hosts[12]

History

The ARPANET, the predecessor of the Internet, had no distributed host name database. Each network node maintained its own map of the network nodes as needed and assigned them names that were memorable to the users of the system. There was no method for ensuring that all references to a given node in a network were using the same name, nor was there a way to read the hosts file of another computer to automatically obtain a copy.

The small size of the ARPANET kept the administrative overhead small to maintain an accurate hosts file. Network nodes typically had one address and could have many names. As local area TCP/IP computer networks gained popularity, however, the maintenance of hosts files became a larger burden on system administrators as networks and network nodes were being added to the system with increasing frequency.

Standardization efforts, such as the format specification of the file HOSTS.TXT in RFC 952, and distribution protocols, e.g., the hostname server described in RFC 953, helped with these problems, but the centralized and monolithic nature of hosts files eventually necessitated the creation of the distributed Domain Name System (DNS).

On some old systems a file named networks is present that is similar to a hosts file, containing names of networks.[13]

Extended applications

In its function of resolving host names, the hosts file may be used to define any hostname or domain name for use in the local system.

Redirecting local domains: Some web service and intranet developers and administrators define locally defined domains in a LAN for various purposes, such as accessing the company's internal resources or to test local websites in development.[14]
Internet resource blocking: Entries in the hosts file may be used to block online advertising, or the domains of known malicious resources and servers that contain spyware, adware, and other malware. This may be achieved by adding entries for those sites to redirect requests to another address that does not exist or to a harmless destination such as the local machine.[15] Commercial software applications may be used to populate the hosts file with entries of known undesirable Internet resources automatically. In addition, user-created hosts files which block nuisance servers are publicly available.[16] [17]

Fravia described these files variously as "scrolls", "precious", and "powerful" in his anti-advertisement pages, where this usage of hosts was first published.

Software piracy: Some pirated versions of software rely on a modified hosts file to prevent software from contacting the activation servers of the publisher, although activation servers sometimes appear in general purpose hosts files.[18]

Security issues

The hosts file may present an attack vector for malicious software. The file may be modified, for example, by adware, computer viruses, or trojan horse software to redirect traffic from the intended destination to sites hosting malicious or unwanted content.[19] The widespread computer worm Mydoom.B blocked users from visiting sites about computer security and antivirus software and also affected access from the compromised computer to the Microsoft Windows Update website.

In some cases, malware has modified the library responsible for loading the hosts file in order to redirect it to a file it is able to control freely.[20]

See also

External links

Notes and References

  1. Web site: The Most Widely Used Name Server Software: BIND. Internet Systems Consortium. History of BIND. 2017-07-01.
  2. Book: Cisco Networking Academy Program: First-Year Companion Guide. Cisco Systems. 2002. 2nd. 676. 1-58713-025-4.
  3. Book: Penetration Testing: A Survival Guide . 18 January 2017 . Packt Publishing Ltd . 978-1-78728-988-8 . en.
  4. Web site: Hosts(5) - Linux manual page .
  5. Web site: Linux Network Administrators Guide: Writing hosts and networks files . May 16, 2010 .
  6. Web site: Hosts File . August 10, 2011 . July 20, 2011 . https://web.archive.org/web/20110720040729/http://support.isoc.net/Page.aspx/117/hosts.html . dead .
  7. Web site: Microsoft KB Q314053: TCP/IP and NBT configuration parameters for Windows XP . August 28, 2010 .
  8. Web site: Microsoft KB 972034 Revision 2.0: default hosts files . August 28, 2010 .
  9. Web site: Mac OS X: How to Add Hosts to Local Hosts File . August 28, 2010 .
  10. Web site: The Haiku/BeOS Tip Server . November 30, 2012 . https://web.archive.org/web/20130128173732/http://betips.net/1997/09/09/aliases-via-the-hosts-file/ . January 28, 2013 . dead .
  11. Web site: Haiku UserGuide:Network . January 17, 2019.
  12. RISC OS 6.14
  13. Web site: Writing hosts and networks Files. 2021-03-02. tldp.org.
  14. Web site: Building / Testing via the Hosts File . Ohio State University Web Hosting . 9 October 2015 . OCIO . 5 August 2018.
  15. Web site: Gordon . -Tx . Gordon and -Tx explanations about the use of Gordon's hosts file . Web Searchlores . +Fravia . 5 August 2018 . FraviaSearchLores . 26 December 2018 . https://web.archive.org/web/20181226003923/http://search.lores.eu/gorhost.htm . dead .
  16. Web site: Hofstetter . Constantin . /etc/hosts to block shock sites etc. . GitHub . 5 August 2018 . ConstanGit.
  17. Web site: Vianello . Francesco "Fravia" . Antiadvertisement Lab . Web Searchlores . +Fravia . 5 August 2018 . FraviaAntiAdvert . 15 May 2009 . https://web.archive.org/web/20090515234238/http://search.lores.eu/antiadve.htm . dead .
  18. Web site: yhosts. GitHub. 21 June 2021.
  19. Web site: Remove Trojan.Qhosts . https://web.archive.org/web/20071021063000/http://www.symantec.com/security_response/writeup.jsp?docid=2003-100116-5901-99&tabid=1 . dead . October 21, 2007 . Symantec . May 16, 2010 .
  20. Web site: Arntz . Pieter . Hosts file hijacks . Malwarebytes Labs . 21 September 2016 . 5 August 2018.