Выбрать главу

Однако синхронный онлайн-опыт - это, пожалуй, самое большое ограничение, с которым сегодня сталкивается Метавселенная, и то, которое труднее всего решить. Проще говоря, интернет не был создан для синхронного совместного опыта. Вместо этого он был создан для обмена статическими копиями сообщений и файлов от одной стороны к другой (а именно к исследовательским лабораториям и университетам, которые получали доступ к ним по одному). И хотя это звучит неправдоподобно ограничивающе, сегодня это вполне подходит почти для всех онлайн-опытов - в частности, потому, что почти ни один из них не требует постоянного подключения, чтобы чувствовать себя живым или, в общем, непрерывным!

Когда пользователь считает, что просматривает "живую" веб-страницу, например постоянно обновляющуюся ленту новостей Facebook или прямую трансляцию выборов от New York Times, на самом деле он просто получает часто обновляемые страницы. На самом деле происходит следующее. Для начала устройство пользователя делает запрос на сервер Facebook или Times через браузер или приложение. Затем сервер обрабатывает запрос и отправляет обратно соответствующий контент. Этот контент включает в себя код, который запрашивает обновления с сервера через определенный интервал времени (скажем, каждые 5 или 60 секунд). Более того, каждая из этих передач (с устройства пользователя или с соответствующего сервера) может проходить через различные сети, чтобы добраться до адресата. Хотя кажется, что это живое, непрерывное и двустороннее соединение, на самом деле это просто пакеты односторонних данных, с различной маршрутизацией и неживые. Та же модель применяется к приложениям, которые мы называем "мгновенными сообщениями". Пользователи и серверы между ними на самом деле просто пересылают друг другу фиксированные данные, при этом часто запрашивая информацию (отправку сообщения или квитанции о прочтении).

Даже Netflix работает не непрерывно, хотя термин "потоковое вещание" и целевой опыт - беспрерывное воспроизведение - говорят об обратном. На самом деле серверы компании отправляют пользователям отдельные порции данных, многие из которых проходят по разным сетевым маршрутам от сервера до пользователя. Часто Netflix даже отправляет контент пользователю раньше, чем это необходимо - например, на дополнительные 30 секунд. Если произойдет временная ошибка в доставке (например, определенный путь будет перегружен или пользователь на короткое время потеряет соединение с Wi-Fi), видео продолжит воспроизведение. Результатом подхода Netflix является доставка, которая кажется непрерывной, но только потому, что она не является таковой.

У Netflix есть и другие хитрости. Например, компания получает видеофайлы от нескольких месяцев до нескольких часов до того, как они станут доступны зрителям. Это дает компании возможность провести обширный анализ на основе машинного обучения, который позволяет уменьшить (или "сжать") размер файла, анализируя данные кадра, чтобы определить, какую информацию можно отбросить. В частности, алгоритмы компании будут "наблюдать" за сценой с голубым небом и решать, что, если пропускная способность интернета зрителя внезапно снизится, 500 различных оттенков голубого можно будет сократить до 200, или 50, или 25. Аналитика стримера даже делает это на основе контекста, понимая, что сцены с диалогами могут быть более сжатыми, чем сцены с быстро развивающимся действием. Кроме того, Netflix будет предварительно загружать контент на локальные узлы. Если вы попросите новый эпизод "Stranger Things", он будет находиться всего в нескольких кварталах от вас и, следовательно, будет доставлен сразу же.

Вышеописанные подходы работают только потому, что Netflix - это несинхронный опыт; вы не можете ничего "предварительно сделать" для контента, который производится в прямом эфире. Именно поэтому прямые видеопотоки, например, CNN или Twitch, значительно менее надежны, чем потоки по запросу от Netflix или HBO Max. Но даже у стримеров есть свои хитрости. Например, передача обычно задерживается на две-тридцать секунд, а значит, остается возможность предварительно отправить контент в случае временной перегрузки. Рекламные паузы также могут использоваться как сервером контент-провайдера, так и пользователем для восстановления соединения, если предыдущее оказалось ненадежным. Большинство видео в реальном времени требует только одностороннего непрерывного соединения - например, от сервера CNN к пользователю. Иногда соединение бывает двусторонним, как в случае с чатом Twitch, но при этом передается лишь небольшой объем данных (сам чат), и он не имеет критического значения, поскольку не влияет непосредственно на происходящее в видео (помните, что это, скорее всего, произошло на две-тридцать секунд раньше).

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

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

Вспомните свой последний вызов Zoom. Время от времени несколько пакетов, скорее всего, приходили слишком поздно или, возможно, вообще не приходили, то есть вы не слышали ни слова, ни двух - или, возможно, несколько ваших слов не были услышаны другими участниками разговора. Несмотря на это, скорее всего, вы или ваши слушатели все равно поняли, что было сказано, и разговор мог продолжаться. Возможно, вы временно потеряли, но затем быстро восстановили связь. Zoom может прислать вам пропущенные пакеты, затем ускорить воспроизведение и отредактировать паузы, чтобы "догнать" вас до "прямого эфира". Возможно, вы полностью потеряли соединение - либо из-за проблем в локальной сети, либо из-за проблемы, возникшей между вашей локальной сетью и удаленным сервером Zoom. Если это произошло, вы, скорее всего, возобновили работу, и никто не узнал о вашем уходе, а если и узнал, то вряд ли ваше отсутствие было разрушительным. Это объясняется тем, что видеоконференции - это совместный опыт, сосредоточенный на одном человеке, а не общий опыт, которым руководят многие пользователи, работающие вместе. А если бы вы были докладчиком? Хорошая новость заключается в том, что разговор может продолжаться и без вас: либо подключится другой участник, либо все будут ждать, когда вы присоединитесь. Если в какой-то момент перегрузка сети приведет к тому, что вы или другие участники просто не смогут услышать или увидеть происходящее, Zoom прекратит загрузку или скачивание видео от разных участников звонка, чтобы приоритетнее использовать то, что важнее всего: звук. Или, наоборот, звонок мог прерываться из-за разной задержки - то есть разные участники звонка получали "живое" видео и аудио на четверть, половину или даже целую секунду позже или раньше друг друга, - что приводило к попыткам говорить по очереди и постоянным прерываниям. В конце концов, участники звонка, вероятно, придумали, как с этим справиться. Просто всем нужно немного терпения.