Безопасен ли мой брандмауэр Linux?

Я новичок в брандмауэрах Linux и пытаюсь настроить системный брандмауэр на общедоступный компьютер. Вот мои требования:

  1. Порты 80 и 22 должны быть открыты для HTTP-запросов и входов SSH
  2. Поскольку мой сервер приложений будет работать под пользователем без полномочий root на порту 8080. Я хочу перенаправить все пакеты на порт 8080. В некоторых случаях мое приложение само делает запрос на сервер изнутри сервера.

Вопрос: Есть ли дыры в моем брандмауэре? Способы я могу сделать это более безопасным.

Вот мои настройки брандмауэра:

*filter
:FORWARD ACCEPT [0:0]
:INPUT ACCEPT [0:0]
:RH-Firewall-1-INPUT - [0:0]
:OUTPUT ACCEPT [0:0]
-A FORWARD -j RH-Firewall-1-INPUT
-A RH-Firewall-1-INPUT -i lo -j ACCEPT
-A RH-Firewall-1-INPUT -p icmp -m icmp --icmp-type any -j ACCEPT
-A RH-Firewall-1-INPUT -p esp -j ACCEPT
-A RH-Firewall-1-INPUT -p ah -j ACCEPT
-A RH-Firewall-1-INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
# Allow Secure SSH transfer
-A RH-Firewall-1-INPUT -p tcp -m state -m tcp --dport 22 --state NEW -j ACCEPT
# Allow all HTTP requests
-A RH-Firewall-1-INPUT -p tcp -m tcp --dport 80 -j ACCEPT
-A RH-Firewall-1-INPUT -j REJECT --reject-with icmp-host-prohibited
COMMIT
*mangle
:FORWARD ACCEPT [0:0]
:INPUT ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
:PREROUTING ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
COMMIT
# Completed
*nat
:OUTPUT ACCEPT [0:0]
-A OUTPUT -p tcp --dport 80 -j REDIRECT --to-ports 8080
:PREROUTING ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
# Routes all HTTP requests from port 80 to port 8080.
# Allows you to run JETTY as a non-root user.
-A PREROUTING -p tcp -m tcp --dport 80 -j REDIRECT --to-ports 8080
COMMIT
# Completed

2 ответа

У вас есть следующая строка в вашей конфигурации:

-A RH-Firewall-1-INPUT -p icmp -m icmp --icmp-type any -j ACCEPT

Однако существует два типа ICMP-запросов, которые можно рассматривать как небольшую проблему безопасности ( введите здесь описание ссылки):

Type  Name                   Reference          
...
13  Timestamp        [RFC792]
...
17  Address Mask Request     [RFC950]

Тип 13 - это запрос на точное время в зависимости от конечного компьютера. Точное время можно использовать для использования некоторых очень слабых алгоритмов шифрования в некоторых сетевых протоколах, что позволяет злоумышленнику получить доступ к конфиденциальной информации. Тип 17 - это запрос маски сети интерфейса, по которому был получен запрос. Правильный ответ может помочь злоумышленнику узнать о топологии вашей сети. Вместо приведенного выше правила я рекомендую следующие три правила:

-A RH-Firewall-1-INPUT -p icmp -m icmp --icmp-type 13 -j REJECT
-A RH-Firewall-1-INPUT -p icmp -m icmp --icmp-type 17 -j REJECT
-A RH-Firewall-1-INPUT -p icmp -m icmp --icmp-type any -j ACCEPT

Эти правила будут запрещать два запрещенных типа ICMP и разрешать все остальные.

Я также довольно новичок в маршрутизации Linux, единственное, что я рекомендовал, - это изменить целевую политику INPUT, чтобы она также удаляла / отклоняла (iptables -P INPUT DROP). По какой-то причине это рекомендуется, даже если ваше последнее правило - УБРАТЬ или ОТКАЗАТЬ, как ваше.

Другие вопросы по тегам