iptables блокирует только некоторые подключения к порту 80

Я использую сервер Ubuntu 15.10 с веб-сервером nginx. Я использовал следующую конфигурацию iptables, чтобы разрешить соединения через порт 80 и порт 443:

*filter

# Allow all loopback (lo0) traffic and reject traffic
# to localhost that does not originate from lo0.
-A INPUT -i lo -j ACCEPT
-A INPUT ! -i lo -s 127.0.0.0/8 -j REJECT

# Allow ping.
-A INPUT -p icmp -m state --state NEW --icmp-type 8 -j ACCEPT

# Allow SSH connections.
-A INPUT -p tcp --dport 950 -m state --state NEW -j ACCEPT

# Allow HTTP and HTTPS connections from anywhere
# (the normal ports for web servers).
-A INPUT -p tcp --dport 80 -m state --state NEW -j ACCEPT
-A INPUT -p tcp --dport 443 -m state --state NEW -j ACCEPT

# Allow mail
-A INPUT -p tcp --dport 25 -m state --state NEW -j ACCEPT

# Allow inbound traffic from established connections.
# This includes ICMP error returns.
-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

# Log what was incoming but denied (optional but useful).
-A INPUT -m limit --limit 5/min -j LOG --log-prefix "iptables_INPUT_denied: " --log-level 7

# Reject all other inbound.
-A INPUT -j REJECT

# Log any traffic which was sent to you
# for forwarding (optional but useful).
-A FORWARD -m limit --limit 5/min -j LOG --log-prefix "iptables_FORWARD_denied: " --log-level 7

Как подтверждено iptables -L:

Chain INPUT (policy ACCEPT)
target     prot opt source               destination
ACCEPT     all  --  anywhere             anywhere
REJECT     all  --  127.0.0.0/8          anywhere             reject-with icmp-port-unreachable
ACCEPT     icmp --  anywhere             anywhere             state NEW icmp echo-request
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:950 state NEW
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:http state NEW
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:https state NEW
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:smtp state NEW
ACCEPT     all  --  anywhere             anywhere             state RELATED,ESTABLISHED
LOG        all  --  anywhere             anywhere             limit: avg 5/min burst 5 LOG level debug prefix "iptables_INPUT_denied: "
REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
LOG        all  --  anywhere             anywhere             limit: avg 5/min burst 5 LOG level debug prefix "iptables_FORWARD_denied: "
REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination

Это работает ... в общем. Некоторые подключения к порту 80 все равно блокируются (/var/log/kern.log):

Apr 15 11:50:47 while kernel: [6038916.249973] iptables_INPUT_denied: IN=eth0 OUT= MAC=04:01:a4:e4:4d:01:84:b5:9c:fa:10:30:08:00 SRC=82.101.237.77 ST=xxx.xxx.xxx.xxx LEN=40 TOS=0x08 PREC=0x00 TTL=54 ID=2368 DF PROTO=TCP SPT=51182 DPT=80 WINDOW=0 RES=0x00 RST URGP=0

Почему iptables делает это?

0
задан 15 April 2016 в 18:52

1 ответ

Ваша запись в журнале в качестве примера для пакета TCP с утверждаемым флагом сброса.

Для соединений TCP, Linux имеет тенденцию использовать "полудуплексную" близкую последовательность, где любая сторона сессии может инициировать завершение соединения через единственные 2 пути квитирование FIN-ACK (который помещает соединение в состояние CLOSE_WAIT), вместо полных 4 путей квитирование FIN-ACK.

Это вероятно, и очень распространено, что Ваша сторона думает, что предыдущий сеанс TCP был закрыт и забыл об этом. Затем 82.101.237.77 пытался сбросить соединение, которое закончилось как "iptables_INPUT_denied".

Сводка: неправильно нет ничего.

0
ответ дан 16 April 2016 в 04:52
  • 1
    Как Вы устанавливали Ubuntu? Путем начальной загрузки к USB или CD? Если Вы делаете это снова, должна была быть точка, где она спросила Вас " Попробуйте Ubuntu" или " Установка Ubuntu". нажмите " Попробуйте Ubuntu" и it' ll загружают временную версию из живого USB или CD. Затем включите USB с достаточным количеством пространства для Ваших файлов, скопируйте свои файлы в него, и Ваши файлы теперь безопасны. Если хуже прибывает в худший абсолютный, Ваши файлы будут, по крайней мере, сохранены. – Nathan Smith 29 August 2017 в 03:04

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

Похожие вопросы: