Automatic block bad IPs with lists from www.stopforumspam.com. The script supports custom blacklist and whitelist.
- iptables
- ipset
- unzip
- wget
-
Login server in root user
-
Copy
ipset_update.sh
to any directory on your server.
bash ipset_update.sh <period>
Example:
bash ipset_update.sh 7
Supported periods:
1
- include IPs list logged within the last 1 day (hourly updates)7
- include IPs list logged within the last 7 day (hourly updates)30
- include IPs list logged within the last 30 day (hourly updates)90
- include IPs list logged within the last 90 day (daily updates)180
- include IPs list logged within the last 180 day (daily updates)365
- include IPs list logged within the last 365 day (daily updates)
Note that there is a limits for day downloading (for the first - 24 daily downloads, for the others - 2 daily downloads). Downloading skip if the local list archive same as in www.stopforumspam.com.
You may create whitelist if you want automatically delete custom IPs from blacklist after it create. Put your IPs in whitelist
file (one per row) in the same directory and run script. You will see appropriate message during script work.
You may create static blacklist if you want automatically add custom IPs to main blacklist after it create. Put your IPs in blacklist
file (one per row) in the same directory and run script. You will see appropriate message during script work.
Add line in root crontab like below
0 0 * * * /bin/bash /path/to/script/ipset_update.sh 7 # daily updates in 00:00 with including IPs list logged within the last 7 day
If you want receive script result to email add below to the top of crontab list (require working MTA on your server)
MAILTO=name@domain.com
Logging is disabled by default to prevent increased load on the server at a large number of IPs blocks. To enable logging, add 1
to the command as the second parameter:
bash ipset_update.sh 7 1
Logging is done in the kernel log (by default, /var/log/kern.log
on deb-based OS, /var/log/messages
on rpm-based OS).
Type for check logging:
grep "REJECT blacklist entry" /path/to/kernel/log
Example:
grep "REJECT blacklist entry" /var/log/kern.log
- 14.04.2022 - 1.4.0 - logging disabled by default, added parameter to enable it
- 13.03.2022 - 1.3.0 - added support for custom static blacklist for add to main blacklist
- 11.10.2020 - 1.2.0 - bugfixes
- 26.11.2018 - 1.1.0 - added whitelist support and added check for successful list download
- 24.12.2017 - 1.0.4 - fixed wrong number of members in set
- 23.12.2017 - 1.0.3 - fixed wrong number of members in set
- 11.06.2017 - 1.0.2 - added flush set before update blacklist
- 15.05.2017 - 1.0.1 - added PATH var for fix errors when run via crontab
- 13.05.2017 - 1.0.0 - released