У меня относительно сложный домашний офис/малый офис сеть-я использую два NAT (преобразование сетевых адресов) маршрутизаторы/межсетевые экраны, чтобы обеспечить DMZ (демилитаризованная зона) для дешевого жертвенного веб-сервера. В принципе, я не хочу компромисса (a.k.a. pwnage) веб-сервера, чтобы легко разрешить доступ к ПК в частной сети. Вот простая диаграмма того, как у меня все настроено:

внешний маршрутизатор позволяет порты 80 и 443 в, направляется на веб-сервер. Внутренний маршрутизатор позволяет ничего in. Теория: если веб-сервер скомпрометирован, частные компьютеры локальной сети по-прежнему защищены внутренним маршрутизатором.

вперед: я недавно купил Apple Airport Extreme для замены существующего внутреннего маршрутизатора NAT. Когда я подключил новый AirPort Extreme к внешнему маршрутизатору, утилита Airport пожаловалась во время установки, что я использую конфигурацию "Double NAT". Я был озадаченный — я никогда не видел такого сообщения от маршрутизатора прежде и никогда не испытывал проблемы с двойной установкой NAT. Я был на двойной установке NAT в течение многих лет.

Итак, почему двойной NAT настолько плох, что мой AirPort Extreme хочет предупредить меня об этом и предложить использовать мостовой режим? Отложив очевидные соображения производительности / задержки в сторону, почему NAT поверх NAT будет плохой вещью? Спасибо!

4 ответов

У меня на самом деле была аналогичная ошибка в моей настройке недавно, когда я перенастроил ее из-за переключения передач.

сообщение double-NAT предназначено как предупреждение о возможной патологической настройке сети, но я думаю, что это не имеет значения, особенно, поскольку вы говорите, что некоторое время запускали эту настройку. Фактически, многие интернет-провайдеры используют NAT в эти дни на своих DSL или кабельных модемах, где каждый клиент уже "позади маршрутизатора", так сказать, даже с одним подключенным устройством непосредственно к модему. Как только клиент добавляет беспроводной маршрутизатор для своего дома, они находятся в ситуации двойного NAT. И это, кажется, работает для большинства людей, очевидно.

согласно моим исследованиям, кажется, что есть некоторые приложения, в основном промышленные VPN и другие приложения, которые манипулируют данными на нижних слоях стека OSI, которые может икота, если они начинают ковыряться внутри пакетов. В частности, компании Cisco по VPN + Установка брандмауэра является одним из примеров я наткнулся на. В качестве другого примера надежность некоторых реализаций VoIP в среде с двойным NAT, казалось, была предметом некоторых дебатов.

Как вы отмечаете, это почти наверняка введут какую-нибудь небольшую сумму дополнительных задержек из-за лишних хоп и работы каждый маршрутизатор, но если ты азартный геймер. meh.

Edit: как указывает Кевин ниже, UPnP также, вероятно, будет урод в сценарии double-NAT, но крайность аэропорта, которая вызвала вопрос не поддерживает UPnP в любом случае.

Цифровой мир — это все адреса IP (интернет-протокола). Каждому устройству требуется IP-адрес для связи в Интернете или в частной сети. Учитывая, что для каждого подключенного к Интернету устройства ( по крайней мере, с IPv4 ) недостаточно публичных IP-адресов, эта мелочь, называемая NAT, становится чрезвычайно важной. Он означает трансляцию сетевых адресов (NAT) и является функцией, предоставляемой маршрутизаторами, позволяющей нескольким устройствам получать доступ к Интернету через один общедоступный IP-адрес.

Благодаря каждому публичному IP-адресу через NAT может быть сотни устройств с собственными частными IP-адресами. И почти все оборудование, предоставляющее функцию NAT, включает брандмауэр для защиты частных IP-адресов и устройств от общедоступных IP-адресов и устройств в Интернете. Также обычно предлагаются другие сетевые службы, такие как DHCP (динамический протокол управления хостом) для выдачи частных IP-адресов устройствам, которые подключаются к локальной сети.

Как получается двойной NAT

Однако наличие нескольких устройств, выполняющих NAT в частной сети, может вызвать проблемы с этой сетью. Некоторые пользователи, возможно, никогда не заметят, что делает их невостребованными для них. Но другие могут столкнуться с головными болями с определенными приложениями, услугами и ситуациями. Таким образом, всегда рекомендуется удалять двойной NAT, если он у вас есть.

Наличие нескольких устройств NAT обычно происходит, когда вы подключаете свой собственный маршрутизатор к шлюзу, установленному вашим провайдером интернет-услуг (ISP), который также включает функции NAT и маршрутизации. Некоторые интернет-провайдеры устанавливают только простой модем, в котором отсутствуют функции NAT и маршрутизации, что полностью устраняет проблему. Однако большинство интернет-провайдеров считают, что у своих клиентов нет маршрутизаторов, поэтому они предоставят вам комбо-устройство, хотите ли вы этого или нет.

Если вы не знаете, что провайдер предоставил вам, взгляните на коробку. Если есть только один порт Ethernet, это, скорее всего, простой модем (он же широкополосный шлюз). Но если есть несколько портов Ethernet или поддерживает Wi-Fi-соединения, это, скорее всего, выполняет NAT и маршрутизацию.

Какие проблемы может вызвать двойной NAT

Когда в вашей сети есть двойной NAT, вы можете столкнуться с проблемами с услугами, для которых требуется поддержка UPnP (Universal Plug-and-Play) или ручная переадресация портов. Это будет включать онлайн-игры на компьютерах или консолях, удаленный рабочий стол на компьютеры, подключение к VPN-серверу или доступ к каналам камеры безопасности. Такие службы иногда требуют, чтобы определенные порты открывались в брандмауэре маршрутизатора и направлялись на определенный компьютер или устройство в сети.

На этом снимке экрана показано, как я настроил свой маршрутизатор для перенаправления портов, чтобы я мог использовать удаленный SSH (Secure Shell) на сервере в локальной сети. Я не могу этого сделать, если мой шлюз также выполняет NAT (преобразование сетевых адресов).

Проблема с двойным NAT заключается в том, что если первый маршрутизатор в вашей сети не настроен для переадресации портов, входящий трафик прекратится там, даже если на втором маршрутизаторе настроен порт вперед. Даже если первый маршрутизатор имеет порт вперед, он не может перенаправить трафик на устройство, подключенное ко второму маршрутизатору. Он может перенаправлять только трафик на компьютеры и устройства, напрямую подключенные к этому первому маршрутизатору, который может быть либо беспроводным, либо проводным.

Двойной NAT также может усложнить любые ручные или автоматические элементы управления качеством обслуживания (QoS), которые определяют приоритетность трафика в вашей внутренней сети, чтобы обеспечить чувствительный к задержкам трафик (игра, голос или видео), которому присваивается более высокий приоритет, чем данные, связанные с файловыми передачами. Это особенно важно, если у вас есть устройства, подключенные к обоим маршрутизаторам, оба из которых имеют разные элементы управления QoS.

На этом снимке экрана отображаются параметры QoS (Quality of Service) моего маршрутизатора, которые я настроил для назначения приоритета VoIP (Voice over Internet Protocol).

Как обнаружить ситуацию с двойным NAT

Я уже упоминал, как быстро определить, имеет ли шлюз ISP возможности NAT и маршрутизации, но вы также можете посмотреть, действительно ли происходит двойной NAT, прежде чем тратить время на эту проблему. Иногда шлюзы обнаруживают двойной NAT и автоматически исправляют проблему для вас. Или иногда, если инсталляторы ISP хорошо осведомлены, они могут исправить это, когда они выходят, чтобы установить шлюз, и убедитесь, что у вас есть собственный маршрутизатор.

Для двух способов я покажу вам, как определить ситуацию с двойным NAT, вам нужно проверить свои IP-адреса и узнать, являются ли они частными или общедоступными. Это легко: частные адреса обычно находятся в диапазоне от 192.168.0.0 до 192.168.255.255, от диапазона 172.16.0.0 до 172.31.255.255 или от 10.0.0.0 до 10.255.255.255. Адресами за пределами этих диапазонов будут публичные (интернет-адреса).

Один быстрый способ, который обычно показывает, что двойной NAT существует, — это traceroute, который позволяет вам пинговать сервер или устройство в Интернете и видеть путь, который требуется между маршрутизаторами и серверами. Откройте командную строку (на ПК с ОС Windows, который подключен к Интернету, щелкните в меню «Пуск», введите «cmd» и нажмите Enter) и введите «tracert 8.8.8.8», чтобы увидеть трассировку на DNS-сервере Google. Если вы видите два личных IP-адреса, перечисленных в первых двух перелетах, у вас есть двойной NAT. Если вы видите только один частный адрес, а второй прыжок показывает общедоступный адрес, тогда вы все хорошо.

Вот traceroute, показывающий двойной NAT, о чем свидетельствуют частные IP-адреса в первых двух прыжках.

Еще один способ проверить двойной NAT — подключиться к веб-интерфейсу вашего маршрутизатора и посмотреть, является ли WAN (интернет) IP-адрес частным или общедоступным. Это должен быть публичный адрес. Если это частный адрес, у вас двойной NAT.

Больше доказательств двойной ситуации с NAT: IP-адрес моего маршрутизатора WAN является закрытым, а не публичным.

Как вы можете это исправить

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

Если вы хотите сохранить свой маршрутизатор, посмотрите, можете ли вы перевести шлюз ISP в мостовой или транзитный режим. Это отключит функции NAT, брандмауэра и DHCP шлюза и уменьшит его до простого интернет-модема. Многие шлюзы предлагают эти настройки, но не все. Войдите в веб-интерфейс GUI шлюза и проверьте настройку NAT, сквозной или мостовой режим, но имейте в виду, что иногда он скрыт. Если вы этого не видите, найдите в Интернете подробную информацию о своей конкретной модели или обратитесь в службу технической поддержки вашего провайдера.

Мой шлюз имеет настройки DMZ в настройках брандмауэра, как это типично для шлюзов.

Еще один вариант устранения двойного NAT при сохранении шлюза ISP и вашего маршрутизатора — это запустить Ethernet-кабель от шлюза к одному из портов LAN вашего маршрутизатора вместо порта WAN (интернет) маршрутизатора. Это в основном превратит ваш маршрутизатор в коммутатор, и любые компьютеры, подключенные через маршрутизатор (проводные или беспроводные), получат NAT, брандмауэр и DHCP от шлюза ISP. Это хороший вариант, если вы используете дополнительный маршрутизатор для улучшения Wi-Fi или потому, что вам нужно больше портов Ethernet. Если, с другой стороны, ваше стремление к другому маршрутизатору для лучшей перенаправления портов или улучшения контроля QoS, этот подход не поможет.

Игры онлайн требуют быстрого и стабильного подключения к игровому сервису или серверу. Если ваша игровая платформа находится за двойным NAT (NAT = Network Address Translation / Преобразование сетевых адресов ), тогда Вы можете столкнуться с рядом проблем при подключении к игре онлайн.

В ситуации одинарного NAT все устройства, подключенные к роутеру, имеют локальный (частный) сетевой адрес. Ваш роутер является шлюзом в Интернет для устройств. В Интернете роутер имеет один публичный IP-адрес.

Двойной NAT – это термин для сценария, при котором роутер подключен не напрямую к Интернету, а к другому роутеру, вследствие чего Ваш роутер не получает публичный IP-адрес. Данная ситуация вызывает проблемы по причине того, что Ваш роутер не доступен для связи напрямую для наших сервисов в Интернете.

Двойной NAT часто можно обнаружить в таких местах, как больницы, студенческие общежития, школы, гостиницы и почти все общественные места с установленной сетевой связью. Для того, чтобы узнать, находитесь ли вы в ситуации с двойным NAT, вы можете попробовать следующее:

— Перейдите к настройкам Вашего роутера (как описано в данном FAQ) и выберите раздел статуса WAN (Wide Area Network) (с видимыми адресами).
В зависимости от производителя и модели Вашего роутера названия разделов могут быть немного другими. Если у вас возникли затруднения с поиском информации, проверьте документацию к роутеру. В качестве альтернативного варианта Вы можете связаться с производителем роутера.
— Проверьте указанный IP-адрес и запомните или запишите его.
— Затем посетите веб-сайт, который позволяет проверить свой публичный IP-адрес.
— Сравните Ваш публичный IP-адрес с тем, который Вы записали ранее. Если они разные, тогда это будет означать, что Вы подключены к другой локальной сети, то есть подключены через двойной NAT.

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

Вполне возможна ситуация, при которой второй роутер будет расположен вне Вашей досягаемости, например, у Интернет-провайдера или сетевого администратора. В данной ситуации Вам нужно будет обратиться за консультацией по данному вопросу к ним напрямую. В качестве возможного решения Вы можете запросить публичный IP-адрес напрямую у Вашего Интернет-провайдера или сетевого администратора.

«>