Обзор RIST и SRT: какой выбрать и почему
Что общего у RIST и SRT?
Оба протокола предназначены для передачи видео с низкой задержкой через общедоступные интернет-сети. SRT изначально был разработан компанией Haivision для применения в их собственных кодерах и декодерах, а в 2017 году стал открытым протоколом для доставки видео в реальном времени. Замечу, компания Haivision — не только разработчик проекта SRT и основатель SRT Alliance, но и член альянса RIST Forum (входит в Video Services Forum).
Разработка RIST стартовала в том же 2017 году. Многие компании применяли разные реализации RIST в своих продуктах, но их решения были не совместимы между собой.
И RIST, и SRT имеют одинаковый уровень шифрования, а также поддерживают вещание высокобитрейтных потоков и Forward Error Correction (SMPTE 2022-1). Оба протокола поддерживают Pre-Shared Key до 256 битов и автоматический запрос повторной передачи пакетов (ARQ), умеют обходить брандмауэр и позволяют балансировать между надёжностью доставки и задержкой.
Сегодня оба протокола реализованы в виде библиотеки с открытым исходным кодом, что позволяет быстрее и проще запускать вещание, а также не зависеть от решения конкретного производителя в отличие от использования проприетарных решений, таких как Zixi.
SRT и RIST присутствуют во многих популярных решениях и фреймворках, например AWS Media Connect, Nimble Streamer, VLC, gstreamer, ffmpeg, wireshark (через плагины). Библиотеки librist и libsrt доступны для всех трёх операционных систем: Windows, Linux и MAC.
В чем разница между протоколами?
SRT изначально был разработан одной компанией на базе UDT (UDP-based Data Transfer Protocol) — широко известного и зарекомендовавшего себя протокола передачи файлов. UDT значительно быстрее TCP и легко конфигурируется. Но, в отличие от файлов, медиаданные значительно больше по объёму и очень восприимчивы к потерям. SRT отлично себя показывает при низком или среднем проценте потерь пакетов, скажем, не более 10–12%. Основной целью SRT было заменить устаревший RTMP, который Amazon перестала поддерживать, а Flash плагины перестали поддерживаться браузерами.
RIST же был совместной разработкой группы экспертов из разных компаний, занимающихся доставкой видеоконтента (ассоциация Video Service Forum и группа технических представителей разных медиакомпаний, образовавших позднее RIST Forum). RIST базируется на протоколах RTP, RTCP и SMPTE-2022 (транспортный поток через IP) и некоторых других интернет-стандартах (RFC). Изначально RIST разрабатывался для передачи видеоконтента и во многом учёл опыт прошлых разработок открытых и проприетарных протоколов для стриминга. RIST способен восстанавливать до 55% регулярных и до 86% кратковременных потерь.
Даже старые плееры, транскодеры, медиасерверы или анализаторы умеют работать с RIST на базовом уровне, принимая RTP, однако с SRT они работать не смогут.
Различаются подходы при авторизации. SRT использует только PSK (pre-shared keys), который предоставляет приемлемый уровень безопасности, но который подходит не всем вещателям. RIST тоже использует PSK, но при этом его можно дополнить SRP (Secure Remote Password) протоколом для дополнительной защиты. Также RIST может работать в режиме DTLS на базе авторизации с помощью сертификата, что является фундаментальным требованием большинства вещателей.
Для обхода брандмауэра в SRT используется концепт рукопожатий caller/listener без настройки перманентных правил, также для этой цели у SRT есть специальный режим rendezvous. Принцип базируется на функции отслеживания соединения у сетевых экранов. В RIST же для обхода брандмауэра используются RTCP сообщения.
Отличаются и методы переотправки потерянных пакетов. SRT не всегда подходит к узким интернет-каналам, потому что при большом количестве ошибок может забить весь канал переотправкой пакетов. Тогда как RIST умеет снижать потребление канала при подобной переотправке. Для реализации ARQ протокол RIST использует только NACK, тогда как в SRT используется и NACK и ACK для подтверждения получения.
SRT умеет работать только в режиме «точка-точка», тогда как у RIST реализован подход «точка — много точек», включая multilink поддержку и мультикаст реализацию. SRT базируется на открытом исходном коде библиотеки c примером реализации от одной конкретной компании, тогда как RIST базируется на открытых спецификациях с участием в разработке группы компаний. В проекте librist активно участвуют добровольцы в качестве тестировщиков и технических писателей.
Почему стоит выбрать SRT?
SRT перевещает потерянные пакеты как можно быстрее, поэтому, если нет ограничения канала по ширине, качество контента будет лучше, а его задержка — ниже.
На сегодняшний день SRT уже успел завоевать определённые позиции на рынке, а также сформировать свой альянс компаний-разработчиков, которые поддерживают этот протокол и используют его в своих решениях. SRT — это проект с открытым исходным кодом, вокруг которого собралось немалое комьюнити. Сейчас альянс насчитывает уже более 450 компаний, включая недавно присоединившихся AWS, OBS и Sony.
SRT также хорошо работает с передачей большого объёма данных, но резко снижает или вовсе теряет свою эффективность при потерях в 15% и более, что подтверждается различными исследованиями.
Сегодня SRT всё ещё более распространён, нежели RIST, поэтому он более эффективен в плане совместимости с потенциальным окружением. SRT, в отличие от RIST, уже присутствует в таких популярных решениях, как OBS Studio и Wowza.
Релиз версии SRT 1.5 был запланирован на 2020 год, но на момент написания статьи ещё официально не вышел. В нём разработчики обещают реализовать бондинг, поддержку C++ 11, двусторонний обмен метаданными, а также улучшить оценку пропускной способности и поддержку мультикаста.
Подробно про SRT я уже писал в этой статье.
Почему стоит выбрать RIST?
RIST умеет вещать в режиме IP multicast, что позволяет значительно экономить трафик и сетевые ресурсы. RIST поддерживает вещание нескольких потоков параллельно (multistream multiplexing), при этом требуется единственный UDP порт. Возможно бесшовное переключение между копиями потока по резервным каналам связи (seamless switching without glitching по широко используемому стандарту SMPTE 2022-7). На приёмной стороне RIST объединяет несколько потоков в один общий поток (link aggregation / bonding).
Поскольку RIST построен на базе RTP, то подавляющее количество устройств, умеющих принимать этот протокол, уже в какой-то степени умеет работать и с RIST (за исключением способности обрабатывать повторную передачу пакетов и другие киллер-фичи RIST).
RIST умеет экономить трафик для повторной передачи пакетов, чтобы добиться стабильности вещания, и избавляться от оверхеда трафика, отсекая нулевые пакеты (паддинг или стаффинг). RIST оптимизирован для передачи высокобитрейтных видео через расширение RTP заголовка, что позволяет увеличить цикл нумерации пакетов с 16 бит до 32. Также RIST считается более надёжным в плане безопасности, так как может работать не только в режиме PSK (Pre-Shared Key), но и использовать DTLS шифрование на базе сертификатов, что считается гораздо более безопасным методом, который используется большинством банков. RIST умеет восстанавливать до 25% потерь с оверхедом в 100% и до 50% потерь с оверхедом в 200%. Во время тестирования на выставке Virtual NAB в 2020 году RIST справился с мгновенными потерями в 86%, при этом все пакеты были доставлены (рис.1).