Я хочу создать действие fail2ban, которое направляет трафик на другой IP-адрес при действии запрета и удаляет маршрут при действии запрета.
Файл: iptables-route.conf в /etc/fail2ban/action.d/
# Fail2Ban configuration file
#
#
[INCLUDES]
before = iptables-common.conf
[Definition]
# Option: actionstart
# Notes.: command executed once at the start of Fail2Ban.
# Values: CMD
#
actionstart = <iptables> -N f2b-<name>
<iptables> -A f2b-<name> -j <returntype>
<iptables> -I <chain> -p <protocol> -m multiport --dports <port> -j f2b-<name>
<iptables> -A FORWARD -i ens3 -p tcp -m state --state NEW --dport 80 -j ACCEPT
<iptables> -A FORWARD -i ens3 -p tcp -m state --state NEW --dport 443 -j ACCEPT
# Option: actionstop
# Notes.: command executed once at the end of Fail2Ban
# Values: CMD
#
actionstop = <iptables> -D <chain> -p <protocol> -m multiport --dports <port> -j f2b-<name>
<actionflush>
<iptables> -X f2b-<name>
<iptables> -D FORWARD -i ens3 -p tcp -m state --state NEW --dport 80 -j ACCEPT
<iptables> -D FORWARD -i ens3 -p tcp -m state --state NEW --dport 443 -j ACCEPT
# Option: actioncheck
# Notes.: command executed once before each actionban command
# Values: CMD
#
actioncheck = <iptables> -n -L <chain> | grep -q 'f2b-<name>[ \t]'
# Option: actionban
# Notes.: command executed when banning an IP. Take care that the
# command is executed with Fail2Ban user rights.
# Tags: See jail.conf(5) man page
# Values: CMD
#
actionban = <iptables> -I f2b-<name> 1 PREROUTING -s <ip> -j DNAT --to-destination 188.68.45.124
# Option: actionunban
# Notes.: command executed when unbanning an IP. Take care that the
# command is executed with Fail2Ban user rights.
# Tags: See jail.conf(5) man page
# Values: CMD
#
actionunban = <iptables> -D f2b-<name> -s <ip> -j DNAT --to-destination 188.68.45.124
[Init]
Файл apache-route.local в /etc/fail2ban/jail.d/:
[apache-route]
enabled = true
filter = apache-probe
port = http,https
banaction = iptables-route.conf
maxretry = 3
findtime = 1500
bantime = 600
logpath = /var/www/*/userdata/logs/*-access.log
Я даже не могу его протестировать, потому что это дает мне следующую ошибку:
fail2ban-перезапуск клиента
Не найдено доступных файлов конфигурации для 'action.d / iptables-route.conf' в / etc / fail2ban
Невозможно прочитать действие iptables-route.conf
Ошибки в тюрьме apache-route. Пропуская...
Я пытаюсь заставить его работать, но понятия не имею, почему это дает мне эту ошибку
Почему просто не iptables-multiport по умолчанию с указанной (перезаписанной) цепочкой и типом блока?
iptables-multiport не добавляет выходные цепочки:
-A ВПЕРЕД -i ens3 -p tcp -m state --state NEW --dport 80 -j ACCEPT
-A ВПЕРЕД -i ens3 -p tcp -m state --state NEW --dport 443 -j ACCEPT
поэтому я решил создать собственное действие, которое добавляет их и удаляет их при загрузке / выгрузке
Я забыл, что мне также нужно реализовать постмаршрутизацию, но мне нужно еще раз подумать, чтобы заархивировать это.
Что я хочу:
при запрете запрос направляется на другой IP-адрес, на котором размещена страница, на которой написано «вы заблокированы из-за слишком большого количества недопустимых запросов» вместо того, чтобы просто отклонить / отбросить запрос
Невозможно прочитать действие iptables-route.conf
Просто удалить .conf
из названия действия:
-banaction = iptables-route.conf
+banaction = iptables-route
Кстати. Мне ваше действие кажется немного неправильным. Почему просто не по умолчанию iptables-multiport
с указанным (перезаписанным) chain
и blocktype
?
Не уверен, что вы пытаетесь, но не будет ли что-то вроде этого:
banaction = iptables-multiport[chain=PREROUTING, blocktype="DNAT --to-destination 188.68.45.124"]
сделать работу?