Пробивка отверстий UDP - Википедия - UDP hole punching

Пробивка отверстий UDP это широко используемый метод, используемый в преобразование сетевых адресов (NAT) приложения для обслуживания Протокол пользовательских датаграмм (UDP) потоки пакетов, проходящие через NAT. Обход NAT методы обычно требуются для сетевых приложений клиент-клиент на Интернет с участием хостов, подключенных в частные сети, особенно в пиринговый, Прямой клиент-клиент (DCC) и Голос по интернет-протоколу (VoIP) развертывания.[1]

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

Обзор

Пробивка отверстий UDP - это метод установления двунаправленных UDP-соединений между Интернет хосты в частных сетях с использованием трансляторов сетевых адресов. Этот метод не применим во всех сценариях или со всеми типами NAT, поскольку рабочие характеристики NAT не стандартизированы.

Хосты с сетевым подключением внутри частной сети, подключенной через NAT к Интернету, обычно используют Утилиты обхода сеанса для NAT (STUN) метод или Установление интерактивного подключения (ICE) для определения публичного адреса NAT, который требуется его узлам связи. В этом процессе другой хост в общедоступной сети используется для установления сопоставления портов и другого состояния порта UDP, которое считается допустимым для прямой связи между хостами приложений. Поскольку состояние UDP обычно истекает через короткие промежутки времени в диапазоне от десятков секунд до нескольких минут,[2] и порт UDP закрывается в процессе, пробивка отверстий UDP использует передачу периодических сохранить жизнь пакетов, каждый из которых обновляет счетчики времени жизни в конечном автомате UDP NAT.

Пробивка отверстий UDP не работает с симметричный NAT устройства (также известные как двунаправленный NAT), которые обычно встречаются в крупных корпоративных сетях. В симметричном NAT отображение NAT, связанное с подключением к известному серверу STUN, ограничивается получением данных от известного сервера, и поэтому отображение NAT, которое видит известный сервер, не является полезной информацией для конечной точки.

При более сложном подходе оба хоста начнут отправлять друг другу сообщения, используя несколько попыток. На Ограниченный конусный NAT, первый пакет от другого хоста будет заблокирован. После этого устройство NAT имеет запись об отправке пакета на другой компьютер и пропускает любые пакеты, приходящие с этого IP-адреса и номера порта. Этот метод широко используется в пиринговый программное обеспечение и Голос по интернет-протоколу телефония. Его также можно использовать для создания виртуальные частные сети работает по UDP. Тот же метод иногда распространяется на Протокол управления передачей (TCP), хотя и с меньшим успехом, потому что потоки TCP-соединений контролируются ОС хоста, а не приложением, а порядковые номера выбираются случайным образом; таким образом, любое устройство NAT, которое выполняет проверку порядкового номера, не будет считать пакеты связанными с существующим соединением и отбрасывать их.

Поток

Пусть A и B - два хоста, каждый в своей частной сети; NА и нB два устройства NAT с глобально доступными IP-адресами EIPА и EIPB соответственно; S - это общедоступный сервер с хорошо известным глобально доступным IP-адресом.

  1. A и B каждый начинают диалог UDP с S; устройства NAT NА и нB создавать состояния трансляции UDP и назначать временные номера внешних портов EPА и EPB.
  2. S проверяет пакеты UDP, чтобы определить порт источника, используемый NА и нB (внешние порты NAT EPА и EPB).
  3. S проходит EIPА: EPА в B и EIPB: EPB к А.
  4. A отправляет пакет в EIPB: EPB.
  5. NА исследует пакет A и создает следующий кортеж в его таблице перевода: (Source-IP-A, EPА, EIPB, EPB).
  6. B отправляет пакет в EIPА: EPА.
  7. NB проверяет пакет B и создает следующий кортеж в его таблице преобразования: (Source-IP-B, EPB, EIPА, EPА).
  8. В зависимости от состояния NАтаблица трансляции при поступлении первого пакета B (то есть, является ли кортеж (Source-IP-A, EPА, EIPB, EPB) был создан к моменту прибытия первого пакета B), первый пакет B отброшен (нет записи в таблице трансляции) или передан (запись в таблице трансляции сделана).
  9. В зависимости от состояния NBтаблица трансляции при поступлении первого пакета A (то есть, является ли кортеж (Source-IP-B, EPB, EIPА, EPА) был создан к моменту прибытия первого пакета A), первый пакет A отброшен (нет записи в таблице трансляции) или передан (запись в таблице трансляции сделана).
  10. В худшем случае второй пакет от A достигает B; в худшем случае второй пакет от B достигает A. Дыры в NAT "пробиты", и оба хоста могут напрямую связываться.
  • Если у обоих хостов есть Ограниченные конусные NAT или же Симметричные NAT, внешние порты NAT будут отличаться от портов, используемых с S. На некоторых маршрутизаторах внешние порты выбираются последовательно, что позволяет установить диалог, угадывая ближайшие порты.

Смотрите также

Рекомендации

  1. ^ «Пробивка отверстий UDP, состояние одноранговой (P2P) связи через трансляторы сетевых адресов (NAT)». ietf.org. 2008-03-01. Получено 2016-06-22.
  2. ^ «Простая безопасность в CPE шлюза IPv6». ietf.org. 2011-01-01. Получено 2016-06-22.

внешняя ссылка