Надежное сжатие заголовков - Robust Header Compression

Надежное сжатие заголовков (ROHC) является стандартизированным методом сжатия IP, UDP, UDP-Lite, RTP, и TCP заголовки Интернет пакеты.

Необходимость сжатия заголовка

В потоковых приложениях накладные расходы IP, UDP и RTP составляют 40 байты для IPv4, или 60 байтов для IPv6. Для VoIP, это соответствует примерно 60% от общего объема отправленных данных. Такие большие накладные расходы могут быть допустимыми в локальных проводных каналах, где пропускная способность часто не является проблемой, но чрезмерна для глобальные сети и беспроводные системы с ограниченной пропускной способностью.[1]

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

Схема сжатия ROHC отличается от других схем сжатия, таких как IETF. RFC 1144 и RFC 2508, благодаря тому факту, что он хорошо работает по каналам с высокой скоростью потери пакетов, например по беспроводным каналам.

Основные принципы сжатия ROHC

Протокол ROHC использует избыточность информации в следующих заголовках:

  • один единственный сетевой пакет (например, длина полезной нагрузки в заголовках IP и UDP)
  • несколько сетевых пакетов, принадлежащих одному потоку (например, IP-адреса)

Избыточная информация передается только в первых пакетах. Следующие пакеты содержат переменную информацию, например идентификаторы или порядковые номера. Эти поля передаются в сжатом виде, чтобы сэкономить больше бит.

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

  • Несжатый
  • Только IP
  • UDP / IP
  • UDP-Lite / IP
  • ESP / IP
  • RTP / UDP / IP
  • RTP / UDP-Lite / IP
  • TCP / IP

Режимы работы

Согласно с RFC 3095, схема ROHC имеет три режима работы, а именно:

  • Однонаправленный режим (U-mode)
  • Двунаправленный оптимистический режим (O-режим)
  • Двунаправленный надежный режим (R-режим)

И компрессор, и декомпрессор запускаются в U-режиме. Затем они могут перейти в O-режим, если доступна пригодная для использования обратная линия, и декомпрессор отправляет компрессору положительное подтверждение с указанным O-режимом. Переход в R-режим осуществляется аналогично.

Однонаправленный режим (U-режим)

В однонаправленном режиме работы пакеты отправляются только в одном направлении: от компрессора к декомпрессору. Таким образом, этот режим позволяет использовать ROHC по каналам связи, где обратный путь от декомпрессора к компрессору недоступен или нежелателен. Чтобы обработать возможные ошибки декомпрессии, компрессор отправляет декомпрессору периодические обновления контекста потока.

Двунаправленный оптимистический режим (режим O)

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

Двунаправленный надежный режим (R-режим)

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

Состояния компрессора / декомпрессора

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

Алгоритм ROHC аналогичен сжатию видео в том, что для представления потока IP-пакетов отправляются базовый кадр, а затем несколько разностных кадров. Это имеет то преимущество, что позволяет ROHC выдерживать многие потери пакетов в состоянии максимального сжатия, пока не будут потеряны базовые кадры.

Состояния компрессора

Конечный автомат компрессора определяет следующие три состояния:

  • Состояние инициализации и обновления (IR)
  • Состояние Первого Порядка (FO)
  • Состояние второго порядка (SO)

Работа в различных состояниях компрессора

В состоянии инициализации и обновления (IR) компрессор только что был создан или сброшен, и отправлены полные заголовки пакетов. В состоянии первого порядка (FO) компрессор обнаружил и сохранил статические поля (такие как IP-адреса и номера портов) на обеих сторонах соединения. Компрессор также отправляет динамические различия полей пакетов в состоянии FO. Таким образом, состояние ОС представляет собой статическое и псевдодинамическое сжатие. В состоянии второго порядка (SO) компрессор подавляет все динамические поля, такие как порядковые номера RTP, и отправляет только логический порядковый номер и частичную контрольную сумму, чтобы другая сторона прогнозированно генерировала и проверяла заголовки следующего ожидаемого пакета. В общем, состояние FO сжимает все статические поля и большинство динамических полей. Состояние SO - это прогнозное сжатие всех динамических полей с использованием порядкового номера и контрольной суммы.

Переходы между состояниями компрессора

Переходы между вышеуказанными состояниями происходят, когда компрессор:

  • сжимает пакет, содержащий слишком много вариантов
  • получает положительную / отрицательную обратную связь от декомпрессора
  • периодически обновляет контекст

Заголовки ROHC второго порядка - 1-байтовые заголовки

Типичная реализация ROHC направлена ​​на перевод терминала в состояние второго порядка, где 1-байтовый заголовок ROHC может быть заменен 40-байтовым IPv4 / UDP / RTP или 60-байтовым IPv6 / UDP / RTP (то есть VoIP). заголовок. В этом состоянии 8-битный заголовок ROHC содержит три поля:

  • 1-битный флаг типа пакета (устанавливается в 1 только для более длинных заголовков ROHC)
  • 4-битный порядковый номер (с диапазоном от -1 до +14 пакетов от базового кадра)
  • 3-битный CRC

Состояния декомпрессора

Конечный автомат декомпрессора определяет следующие три состояния:

  • Состояние без контекста
  • Статическое состояние контекста
  • Состояние полного контекста

Переходы между вышеуказанными состояниями происходят, когда декомпрессор:

  • успешно распаковывает пакет
  • не может распаковать несколько пакетов

Надежность

Размер поля порядкового номера (SN) определяет количество пакетов, которые ROHC может потерять до того, как компрессор должен быть сброшен для продолжения. Алгоритм W-LSB используется для надежного сжатия SN. Размер порядкового номера в 1- и 2-байтовых пакетах ROHC составляет либо 4 бита (смещение кадра −1 / + 14), либо 6 бит (смещение кадра −1 / + 62) соответственно, поэтому ROHC может выдержать не более 62 потерь. кадры с заголовком 1-2 байта.

Дополнительные профили сжатия

В RFC 3095 определяет общий механизм сжатия. Его можно расширить, определив новые профили сжатия, предназначенные для определенных заголовков протокола. Были опубликованы новые RFC для сжатия новых протоколов:

  • В RFC 3843 определяет профиль сжатия для IP-заголовков или IP-туннелей.
  • В RFC 4019 определяет профиль сжатия для заголовков UDP-Lite / IP и RTP / UDP-Lite / IP.
  • В RFC 6846 определяет профиль сжатия для заголовков TCP / IP.

Новые RFC ROHC

Опубликовано два новых RFC RFC 4995 и RFC 5225 чтобы устранить путаницу, с которой некоторые столкнулись при попытке интерпретировать и реализовать ROHC. Первый документ определяет структуру ROHC, а второй определяет более новые версии установленных профилей ROHC.

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

использованная литература

  1. ^ Майкл Дош и Стив Черч. "VoIP в студии вещания". Axia Audio. Архивировано из оригинал на 2011-10-07. Получено 2011-06-21.

внешние ссылки