Защита ssh средствами iptables
Ограничение количества подключений
Для защиты от brute force (перебора паролей), можно ограничить количество подключений на 22 порт с одного ip адреса до нескольких раз в минуту, после чего блокировать попытки подключения для данного ip.
## Создание цепочки правил sshguard # Максимум 2 новых запроса в минуту для одного ip /sbin/iptables -N sshguard # Вкл. лог по желанию #/sbin/iptables -A sshguard -m state --state NEW -m recent --name SSH --rcheck --seconds 60 --hitcount 2 -j LOG --log-prefix "SSH-shield: " /sbin/iptables -A sshguard -m state --state NEW -m recent --name SSH --update --seconds 60 --hitcount 2 -j DROP /sbin/iptables -A sshguard -m state --state NEW -m recent --name SSH --set -j ACCEPT /sbin/iptables -A sshguard -j ACCEPT ## Применение для трафика ssh цепочку sshguard /sbin/iptables -A INPUT -p tcp --dport 22 -j sshguard
recent — это модуль ядра (Core Netfilter Configuration), позволяет создавать динамические списки адресов IP. Модуль поддерживает ряд опций
-
--name name : имя списка, с которым работает команда. По умолчанию для списка используется имя DEFAULT
-
--rcheck : опция будет проверять наличие адреса отправителя пакета в списке При отсутствии адреса в списке возвращается значение false.
-
--update : опция будет проверять наличие адреса отправителя пакета в списке. Если адрес присутствует, соответствующая запись обновляется. При отсутствии адреса в списке возвращается значение false.
-
--hitcount hits : счетчик, возвращает true при наличии адреса в списке, когда число принятых пакетов с адреса больше или равно заданного значения. Используется совместно с rcheck или update
-
--seconds seconds : определяет период (от момента занесения адреса в список), в течение которого адрес может находиться в списке
-
--set : служит для добавления адреса отправителя пакета в список. Если такой адрес уже есть в списке, запись будет обновлена
-
--remove : удалить адрес из списка. Если адрес не обнаружен вернет false.
Опции могут использоваться с инверсией (!)
Динамическое открытие/закрытие ssh порта
Небольшое правило для iptables помогающее лишний раз не держать порты открытыми.
Пример для доступа к SSH, хотя как сами понимаете можно использовать как угодно.
Суть правила проста — для того чтобы открыть доступ к шеллу нужно сначала стукнуться на 1500 порт:
telnet'ом например:
telnet myserver 1500
или через браузер:
http://192.168.0.100:1500
соответственно если стукнуть на 1499 — то порт закроется
iptables -N sshguard # Если адрес в списке, то подключение разрешено iptables -A sshguard -m state --state NEW -m recent --rcheck --name SSH -j ACCEPT # Разрешить пакеты для уже установленных соединений iptables -A sshguard -m state --state ESTABLISHED,RELATED -j ACCEPT iptables -A sshguard -j DROP # Заносит адрес в список #iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 1500 -j LOG --log-prefix "SSH-open: " iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 1500 -m recent --name SSH --set -j DROP # Удаляет адрес из списка iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 1499 -m recent --name SSH --remove -j DROP # Применение для трафика ssh цепочку sshguard iptables -A INPUT -p tcp --dport 22 -j sshguard
Открытие порта ssh на заданное время
Еще один пример демонстрирует способ открытия порта ssh для определенного ip на заданное время.
## определяем цепочку для SSH трафика iptables -N sshguard iptables -F sshguard # Разрешить подключение если ip есть в списке и последнее подключение осуществлялось не позднее 108000 секунд (30 часов) iptables -A sshguard -m state --state NEW -m recent --update --seconds 108000 --name SSH -j ACCEPT # Разрешить пакеты для уже установленных соединений iptables -A sshguard -m state --state ESTABLISHED,RELATED -j ACCEPT # Заблокировать если нет в списке iptables -A sshguard -j DROP ## Открытие SSH iptables -A INPUT -m state --state NEW -p tcp --dport 222 -m recent --name SSH --set ## Фильтрация ssh трафика через цепочку sshguard iptables -A INPUT -p tcp --dport 22 -j sshguard
Теперь, чтобы получить ssh доступ нужно сперва постучаться на порт 222, например так:
ssh user@server.name -p 222
после этого доступ для вашего ip на 22 порт будет разрешен на указанное время, при этом каждый новый коннект на ssh будет продлевать это время. Если вы не хотите продления времени то замените --update --seconds 108000 на --rcheck.
cat /proc/net/ipt_recent/SSH