Consolidating and extending hosts files from several well-curated sources. Optionally pick extensions for porn, social media, and other categories.
Go to file
2016-12-18 10:49:04 -05:00
alternates Regenerated new hosts files. 2016-12-18 00:36:37 -05:00
data New data from Fake News and yoyo.org. 2016-12-18 00:36:09 -05:00
extensions New data from Fake News and yoyo.org. 2016-12-18 00:36:09 -05:00
.editorconfig Add .editorconfig to the repository. 2016-12-18 10:49:04 -05:00
.gitignore latest gitignore. 2016-12-17 13:47:14 -05:00
blacklist add an optional blacklist file 2016-12-10 14:17:56 -06:00
history.md Renaming history.md to all-lowercase. 2016-03-27 18:16:48 -04:00
hosts Regenerated new hosts files. 2016-12-18 00:36:37 -05:00
license.txt Formatting of license.txt. 2016-03-05 11:55:08 -05:00
makeHosts New extension, and attendant combinations: FAKENEWS 2016-12-17 14:28:47 -05:00
makeHostsWindows.bat BAT files: change PATH for lookin DLL file check 2016-12-16 11:34:13 +01:00
myhosts Added a line to myhosts, for better clarity in the generated file. 2015-10-30 11:16:07 -04:00
readme_template.md Update the readme_template for the non-github mirror versions. 2016-12-15 13:18:58 -05:00
readme.md Regenerated new hosts files. 2016-12-18 00:36:37 -05:00
readmeData.json Regenerated new hosts files. 2016-12-18 00:36:37 -05:00
updateHostsFile.py Refactoring in updateHostsFile.py 2016-12-18 00:34:12 -05:00
updateHostsWindows.bat BAT files: change PATH for lookin DLL file check 2016-12-16 11:34:13 +01:00
updateReadme.py Update the readme_template for the non-github mirror versions. 2016-12-15 13:18:58 -05:00
whitelist Create whitelist 2015-11-05 10:47:55 -03:00

#Unified hosts file with base extensions

This repository consolidates several reputable hosts files, and merges them into a unified hosts file with duplicates removed. This repo provides several hosts files tailored to you need to block.

List of all hosts file variants

The Non Github mirror is the link to use for some hosts file managers like Hostsman for Windows that don't work with Github download links.

Host file recipe Readme Raw hosts hosts (.zip) Unique domains Non Github mirror
Unified hosts = (adware + malware) Readme link link 31,865 link
Unified hosts + fakenews Readme link link 32,380 link
Unified hosts + gambling Readme link link 33,385 link
Unified hosts + porn Readme link link 38,101 link
Unified hosts + social Readme link link 32,095 link
Unified hosts + fakenews + gambling Readme link link 33,900 link
Unified hosts + fakenews + porn Readme link link 38,616 link
Unified hosts + fakenews + social Readme link link 32,610 link
Unified hosts + gambling + porn Readme link link 39,621 link
Unified hosts + gambling + social Readme link link 33,615 link
Unified hosts + porn + social Readme link link 38,331 link
Unified hosts + fakenews + gambling + porn Readme link link 40,136 link
Unified hosts + fakenews + gambling + social Readme link link 34,130 link
Unified hosts + fakenews + porn + social Readme link link 38,846 link
Unified hosts + gambling + porn + social Readme link link 39,851 link
Unified hosts + fakenews + gambling + porn + social Readme link link 40,366 link

Expectation: These unified hosts files should serve all devices, regardless of OS.

Sources of hosts data unified in this variant

Updated hosts files from the following locations are always unified and included:

Host file source Description Home page Raw hosts Update frequency
AdAway AdAway is an open source ad blocker for Android using the hosts file. link raw occasionally
add.2o7Net 2o7Net tracking sites based on http://www.hostsfile.org/hosts.html content. link raw occasionally
add.Dead Dead sites based on http://www.hostsfile.org/hosts.html content. link raw occasionally
add.Risk Risk content sites based on http://www.hostsfile.org/hosts.html content. link raw occasionally
add.Spam Spam sites based on http://www.hostsfile.org/hosts.html content. link raw occasionally
KADhosts Fraud/adware/scam websites. link raw frequently
Malware Domain List Malware Domain List is a non-commercial community project. link raw weekly
MVPS hosts file The purpose of this site is to provide the user with a high quality custom HOSTS file. link raw monthly
Dan Pollock someonewhocares.org How to make the internet not suck (as much). link raw frequently
SpotifyAds Spotify ads sources sites based on https://github.com/Xeroday/Spotify-Ad-Blocker content. link raw occasionally
Steven Black's ad-hoc list Additional sketch domains as I come across them. link raw occasionally
Telemetry Windows users tracking sites based on https://github.com/Nummer/Destroy-Windows-10-Spying content. link raw occasionally
tyzbit Microsoft tracking domains. A fork of this repo providing additional data. link raw rarely
UncheckyAds Windows installers ads sources sites based on https://unchecky.com/ content. link raw occasionally
yoyo.org Blocking with ad server and tracking server hostnames. link raw frequently

Extensions

The unified hosts file is extensible. You manage extensions by curating the extensions/ folder tree. See the social, gambling, and porn extension folders.

Generate your own unified hosts file

The updateHostsFile.py script, which is python 2.7 and Python 3-compatible, will generate a unified hosts file based on the sources in the local data/ subfolder. The script will prompt you Whether it should fetch updated versions (from locations defined by the update.info text file in each source's folder), otherwise it will use the hosts file that's already there.

Usage

Using Python 3:

python3 updateHostsFile.py [--auto] [--replace] [--ip nnn.nnn.nnn.nnn] [--extensions ext1 ext2 ext3]

Using Python 2.7:

python updateHostsFile.py [--auto] [--replace] [--ip nnn.nnn.nnn.nnn] [--extensions ext1 ext2 ext3]

Command line options:

--help, or -h: display help.

--auto, or -a: run the script without prompting. When --auto is invoked,

  • Hosts data sources, including extensions, are updated.
  • No extensions are included by default. Use the --extensions or -e flag to include any you want.
  • Your active hosts file is not replaced unless you include the --replace flag.

--backup, or -b: Make a backup of existing hosts file(s) as you generate over them.

--extensions <ext1> <ext2> <ext3>, or -e <ext1> <ext2> <ext3>: the names of subfolders below the extensions folder containing additional category-specific hosts files to include in the amalgamation. Example: --extensions porn or -e social porn.

--flush-dns-cache, or -f: skip the prompt for flushing the DNS cache. Only active when --replace is also active.

--ip nnn.nnn.nnn.nnn, or -i nnn.nnn.nnn.nnn: the IP address to use as the target. Default is 0.0.0.0.

--noupdate, or -n: skip fetching updates from hosts data sources.

--output <subfolder>, or -o <subfolder>: place the generated source file in a subfolder. If the subfolder does not exist, it will be created.

--replace, or -r: trigger replacing your active hosts

--skipstatichosts, or -s: false (default) or true, omit the standard section, at the top containing lines like 127.0.0.1 localhost. This is useful for configuring proximate DNS services on the local network.

--zip, or -z: false (default) or true, additionally create a zip archive of the hosts file named hosts.zip.

How do I control which sources are unified?

Add one or more additional sources, each in a subfolder of the data/ folder, and specify the url key in its update.json file.

Add one or more optional extensions, which originate from subfolders of the extensions/ folder. Again the url in update.info controls where this extension finds its updates.

Create an optional blacklist file. The contents of this file (containing a listing of additional domains in hosts file format) are appended to the unified hosts file during the update process. A sample blacklist is included, and may be modified as you desire.

  • NOTE: The blacklist is not tracked by git, so any changes you make won't be overridden when you git pull this repo from origin in the future.

How do I include my own custom domain mappings?

If you have custom hosts records, place them in file myhosts. The contents of this file are prepended to the unified hosts file during the update process.

The myhosts file is not tracked by git, so any changes you make won't be overridden when you git pull this repo from origin in the future.

How do I prevent domains from being included?

The domains you list in the whitelist file are excluded from the final hosts file.

The whitelist uses partial matching. Therefore if you whitelist google-analytics.com, that domain and all its subdomains won't be merged into the final hosts file.

The whitelist is not tracked by git, so any changes you make won't be overridden when you git pull this repo from origin in the future.

What is a hosts file?

A hosts file, named hosts (with no file extension), is a plain-text file used by all operating systems to map hostnames to IP addresses.

In most operating systems, the hosts file is preferential to DNS. Therefore if a domain name is resolved by the hosts file, the request never leaves your computer.

Having a smart hosts file goes a long way towards blocking malware, adware, and other irritants.

For example, to nullify requests to some doubleclick.net servers, adding these lines to your hosts file will do it:

# block doubleClick's servers
0.0.0.0 ad.ae.doubleclick.net
0.0.0.0 ad.ar.doubleclick.net
0.0.0.0 ad.at.doubleclick.net
0.0.0.0 ad.au.doubleclick.net
0.0.0.0 ad.be.doubleclick.net
# etc...

We recommend using 0.0.0.0 instead of 127.0.0.1

Traditionally most host files use 127.0.0.1, the loopback address, to establish an IP connection to the local machine.

We prefer to use ``0.0.0.0`, which is defined as a non-routable meta-address used to designate an invalid, unknown, or non applicable target.

Using 0.0.0.0 is empirically faster, possibly because there's no wait for a timeout resolution. It also does not interfere with a web server that may be running on the local PC.

Why not use just 0 instead of 0.0.0.0?

We tried that. Using 0 doesn't work universally.

Location of your hosts file

To modify your current hosts file, look for it in the following places and modify it with a text editor.

Mac OS X, iOS, Android, Linux: /etc/hosts folder.

Windows: %SystemRoot%\system32\drivers\etc\hosts folder.

Reloading hosts file

Your operating system will cache DNS lookups. You can either reboot or run the following commands to manually flush your DNS cache once the new hosts file is in place.

Mac OS X

Open a Terminal and run:

sudo dscacheutil -flushcache;sudo killall -HUP mDNSResponder

Windows

makeHostsWindows.bat BATCH file will create various alternate hosts files by combining and adding the gambling, porn, and social media extensions. You need to be connected to the Internet. This file REQUIRED installed Python 3.5.x runtime environment in Windows System. Launch this file as normal user.
Run updateHostsWindows.bat BATCH file in Command Prompt with Administrator privileges in repository directory for easy update, replace hosts file and reload DNS cache in Windows System. You need to be connected to the Internet. This file REQUIRED installed Python 3.5.x runtime environment in Windows System.
WARNING: Don't run these BAT files directly or from popup menu. You have been warned.

Open a Command Prompt in directory where are files from this repository:

Windows XP: Start -> Run -> cmd

Windows Vista, 7: Start Button -> type cmd -> right-click Command Prompt -> "Run as Administrator"

Windows 8: Start -> Swipe Up -> All Apps -> Windows System -> right-click Command Prompt -> "Run as Administrator"

Windows 10: Start Button -> type cmd -> right-click Command Prompt -> "Run as Administrator"

and run command:

updateHostsWindows.bat
If you want using huge hosts file with merged hphosts (NOT INCLUDED HERE) you need to DISABLE and STOP Dnscache service before you replace hosts file in Windows Systems. You have been warned.

Open a Command Prompt with Administrator privileges and run once commands:

sc config "Dnscache" start= disabled
sc stop "Dnscache"

Linux

Open a Terminal and run with root privileges:

Debian/Ubuntu sudo /etc/rc.d/init.d/nscd restart

Linux with systemd: sudo systemctl restart network.service

Fedora Linux: sudo systemctl restart NetworkManager.service

Arch Linux/Manjaro with Network Manager: sudo systemctl restart NetworkManager.service

Arch Linux/Manjaro with Wicd: sudo systemctl restart wicd.service

Others: Consult this wikipedia article.

Goals of this unified hosts file

The goals of this repo are to:

  1. automatically combine high-quality lists of hosts,

  2. provide easy extensions,

  3. de-dupe the resultant combined list,

  4. and keep the resultant file reasonably sized.

A high-quality source is defined here as one that is actively curated. A hosts source should be frequently updated by its maintainers with both additions and removals. The larger the hosts file, the higher the level of curation is expected.

For example, the (huge) hosts file from hosts-file.net is not included here because it is very large (300,000+ entries) and doesn't currently display a corresponding high level of curation activity.

It is expected that this unified hosts file will serve both desktop and mobile devices under a variety of operating systems.