Difference between revisions of "Installing xtables-addons on Raspbian"
| Line 27: | Line 27: | ||
| Download it from SourceForge. Then unpack it, configure it, make it, install it: | Download it from SourceForge. Then unpack it, configure it, make it, install it: | ||
|   <nowiki># in some nice location, eg. the home directory, do: |   <nowiki># in some nice location, eg. the home directory, do: | ||
| − | + | tar -xf xtables-addons-2.5.tar.xz | |
| − | + | cd xtables-addons-2.5 | |
| − | + | ./configure | |
| − | + | make | |
| # if everything went fine, install it: | # if everything went fine, install it: | ||
| − | + | sudo make install</nowiki> | |
| + | |||
| + | You can disable unneeded moudules by editing the file 'mconfig' and speed-up the process. | ||
| + | |||
| + | |||
| + | ==Download and build the geoip database== | ||
| + | As root (sudo -i): | ||
| + |  <nowiki>mkdir /usr/share/xt_geoip | ||
| + | cd /usr/share/xt_geoip | ||
| + | /usr/lib/xtables-addons/xt_geoip_dl | ||
| + | /usr/lib/xtables-addons/xt_geoip_build -D . *.csv | ||
| + | </nowiki> | ||
Revision as of 01:04, 10 January 2015
Contents
Why?
Annoyed by tons of SSH brutforce attacs, I was looking for a way to lock out connections coming from other countries than the desired ones. xtables-addons got the geoip module which enables us to use rules like
iptables -A INPUT -i wan -p tcp --dport 22 -m state --state NEW -m geoip ! --src-cc AT,DE -j GEOIP_BLOCK_LOG
This example would match on connections not originating from Austria (AT) or Germany (DE). I wanted to use it on a Raspberry Pi running Raspbian.
How?
Raspbian, a Debian based operating system for the Raspberry Pi, is a bit different to other Debian distributions when it comes to add kernel modules. The Kernel sources can not be installed using the packet manager but are downloaded and set up by a separate tool.
Getting the latest kernel and sources
- Update to the latest kernel and firmware using the rpi-update script as described here.
- Reboot the Pi
- Download and install the kernel source using rpi-source, see rpi-source.
Install packets from the repository
sudo apt-get install libtext-csv-xs-perl geoip-database libgeoip1
Other tools might be required. Please tell me if anything is missing here.
Debain How To´s on that topic describe the use of module-assistant for making the kernel modules. I did not succeed using it on Raspbian!
Get the xtables-addons source
On the 9th of January 2014, with Raspbian kernel version 3.12.35+ and iptables version 1.4.14, I decided to go with xtables-addons version 2.5.
Download it from SourceForge. Then unpack it, configure it, make it, install it:
# in some nice location, eg. the home directory, do: tar -xf xtables-addons-2.5.tar.xz cd xtables-addons-2.5 ./configure make # if everything went fine, install it: sudo make install
You can disable unneeded moudules by editing the file 'mconfig' and speed-up the process.
Download and build the geoip database
As root (sudo -i):
mkdir /usr/share/xt_geoip cd /usr/share/xt_geoip /usr/lib/xtables-addons/xt_geoip_dl /usr/lib/xtables-addons/xt_geoip_build -D . *.csv

