Назад | Перейти на главную страницу

Правильное открытие порта 443 в интернет

Мне нужен порт 443, открытый для Интернета на моем сервере.

Когда я проверяю внутри через netstat -tulpn | grep "nginx", Я вижу, что nginx действительно СЛУШАЕТ этот порт. Однако пытаясь nmap -p443 mysite.com с внешней машины сообщает, что порт 443 - это фильтрованный. Аналогично, делая telnet <IP Address> 443 время вышло. Как мне убедиться, что этот порт открыт?

FYI в /etc/iptables/rules.v4 Имею следующее:

*filter
# Allow all outgoing, but drop incoming and forwarding packets by default
:INPUT DROP [0:0]
:FORWARD DROP [0:0]
:OUTPUT ACCEPT [0:0]

# Custom per-protocol chains
:UDP - [0:0]
:TCP - [0:0]
:ICMP - [0:0]

# Acceptable UDP traffic

# Acceptable TCP traffic
-A TCP -p tcp --dport 22 -j ACCEPT
-A TCP -p tcp --dport 80 -j ACCEPT
-A TCP -p tcp --dport 443 -j ACCEPT

# Acceptable ICMP traffic

# Boilerplate acceptance policy
-A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
-A INPUT -i lo -j ACCEPT

# Drop invalid packets
-A INPUT -m conntrack --ctstate INVALID -j DROP

# Pass traffic to protocol-specific chains
## Only allow new connections (established and related should already be handled)
## For TCP, additionally only allow new SYN packets since that is the only valid
## method for establishing a new TCP connection
-A INPUT -p udp -m conntrack --ctstate NEW -j UDP
-A INPUT -p tcp --syn -m conntrack --ctstate NEW -j TCP
-A INPUT -p icmp -m conntrack --ctstate NEW -j ICMP

# Reject anything that's fallen through to this point
## Try to be protocol-specific w/ rejection message
-A INPUT -p udp -j REJECT --reject-with icmp-port-unreachable
-A INPUT -p tcp -j REJECT --reject-with tcp-reset
-A INPUT -j REJECT --reject-with icmp-proto-unreachable

# Commit the changes
COMMIT

*raw
:PREROUTING ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
COMMIT

*nat
:PREROUTING ACCEPT [0:0]
:INPUT ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
COMMIT

*security
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
COMMIT

*mangle
:PREROUTING ACCEPT [0:0]
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
COMMIT

Что я делаю не так?

Обратите внимание, что в моем случае веб-приложение (Django) и база данных (postgresql) находятся на двух отдельных виртуальных машинах. Мой веб-сервер уже настроен для HTTPS.

Если это ваш загруженный брандмауэр, и вы подключаетесь через IPv4, то между вами и вашим сервером есть другой брандмауэр, который выполняет фильтрацию.

По умолчанию порт 443 указан LISTEN в файле конфигурации всех веб-серверов и привязан к сайтам, использующим SSL.

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

Используйте Telnet, чтобы проверить, открыт ли порт.

root @ ping # telnet IP-адрес 443

Убедитесь, что порт открыт, но вы все еще не подключаетесь, затем проверьте, что ваши привязки IP-адреса и домена с портом 443 правильно указаны в /etc/httpd/conf/httpd.conf и IIS для Windows.

Если нет, то разрешите этот порт с помощью iptables.

iptables -I INPUT -p tcp --dport 443 -j Accept (для Linux)

Создайте собственное правило брандмауэра в панели управления и разрешите порт 443 для всех входящих подключений (для Windows).