Можно ли играть в валорант на линукс
С самого начала разработки у нас стояли жёсткие требования производительности сервера. В этой статье мы расскажем о том, зачем они нужны, как мы решили наши амбициозные задачи и о технических подробностях наших поисков. Сначала кадр обрабатывался на сервере за 50 мс, а в итоге мы достигли значения менее 2 мс на кадр. Все это благодаря оптимизации кода, работы оборудования и настроек ОС.
Все онлайн-шутеры (удивительно, но даже VALORANT) страдают от преимущества нападающего. Если вкратце, то ключевая задача в VALORANT – занимать и удерживать стратегические позиции. Последнее бывает невозможно сделать, если другой игрок выбегает из-за угла и благодаря задержке передачи данных убивает обороняющегося до того, как тот среагирует. Эта задержка зависит как от сетевого подключения, так и от тикрейта сервера. Чтобы дать обороняющимся время на реакцию, мы решили, что VALORANT нужны серверы с тикрейтом 128. Но об этом мы уже рассказывали в статье про сетевой код.
Главное ограничение для серверов с тикрейтом 128 – ресурсы ЦП. Полный кадр должен обрабатываться за 7.8125 мс, но в таком случае одна игра будет задействовать целое ядро процессора!
На этой схеме показано, сколько игр могут обрабатываться на одном ядре:
Использование целого ядра на одну игру привело бы к большой стоимости обслуживания наших серверов. Но мы хотели, чтобы игра на серверах с тикрейтом 128 была бесплатной для всех игроков, а не премиум-сервисом, доступным за доплату. Вбив цифры в калькулятор, мы определили, что на одном ядре должно обрабатываться более 3 игр. В основном мы используем процессоры с 36 ядрами, то есть каждый физический сервер должен обрабатывать 108 игр, или данные 1080 игроков. 3 игры на ядро – это тоже недёшево, но руководство Riot поддержало наши стремления.
Если разделить 7.8125 мс на 3 игры на ядро, мы получим 2.6 мс. Но еще нужно выделить 10% под работу ОС, планировщик задач и другие процессы на сервере. Получается, что у нас всего 2.34 мс на кадр. Когда мы начинали работу, кадр в VALORANT обрабатывался за 50 мс. Путь оптимизации был долгим и тернистым: для решения этой задачи пришлось бы задействовать всю команду разработки.
«Сделать сервер в 20 раз быстрее» — достаточно абстрактная задача, поэтому мы воспользовались лучшей техникой работы над ПО: разбили большую задачу на маленькие и решаемые по отдельности. Нужно было понять, на что тратятся эти 50 мс, чтобы уменьшить временные затраты. Мы с руководителями технических отделов VALORANT определили большие категории данных, которые требуют много ресурсов ЦП:
- репликация
- «туман войны»
- сеть
- анимации
- геймплей
- движение
- предметы
- персонажи
- физика
- прочее
На основе этого списка мы создали систему, с помощью которой программисты могли легко помечать код игры и делить его на эти категории. Каждая исполняемая строка кода была отнесена к одной из этих областей и включена в макросистему. Также мы добавили разделение на более мелкие подсистемы для точного анализа больших систем. Макросистема получила название ValSubsystemTelemetry.
Теперь при запуске игры мы можем следить за тем, сколько времени уходит на разные категории.
И так, теперь у нас есть библиотека и мы генерируем кучу данных. Что делать?
Работа в крупной студии, типа Riot, позволяет использовать технологии, разработанные другими отделами. В данном случае, основная команда разработала технологию Analytics Platform, используемую для отправки данных в хранилище и визуализации.
Так мы визуализировали данные о производительности VALORANT:
Без таких данных непроизводительные код или изменения контента часто остаются незамеченными. Могло пройти несколько недель, прежде чем эти проблемы накопились и игроки или разработчики заметили бы падение производительности.
Анализ большого количества прошлых обновлений – это очень затратно, но мониторинг данных производительности существенно упрощает задачу. На втором изображении выше можно увидеть проблему между изменениями 445887 и 446832, которая привела к замедлению репликации (оранжевая линия). Такая визуализация сужает массив изменений, и мы можем быстро назначить разработчика для решения проблемы.
После визуализации данных мы смогли установить задачи для каждой подсистемы и разобраться со всеми нестыковками. Мы снова встретились с руководителями технических отделов VALORANT и обсудили, как можно оптимизировать эти системы. Теперь у каждой команды и специалиста была задача, и мы могли вместе работать над улучшением производительности.
Здесь можно увидеть некоторые предварительные данные о категориях, которые упоминались выше:
Для демонстрации оптимизационной работы будет достаточно примеров двух категорий. Сначала мы расскажем о репликации, потому что ей требовались наибольшие изменения (в 10 раз быстрее), а затем поговорим об анимации, потому что её изменения дают хорошее представление о решениях в других категориях.
Репликация объектов или просто репликация – это система в Unreal Engine 4 (UE4), которая позволяет синхронизировать состояние сервера и клиента. Она отлично подходит для быстрого прототипирования новых персонажей, умений и настроек, для которых нужно сетевое взаимодействие с клиентами. Разработчик может просто пометить переменную как «реплицированную», и она будет автоматически синхронизирована между сервером и клиентами.
К сожалению, она довольно медленная. Она сканирует все реплицированные переменные для каждого кадра, потом сравнивает их с 10 последними известными состояниями клиента, выявляет все расхождения и отправляет клиенту изменения. Это по сути рандомные прыжки по памяти и на них требуется много кэша. Переменные проверяются независимо от изменений. Подобные «опрашивающие» системы я считаю антагонистами производительности.
Проблема была решена с помощью другого сетевого инструмента UE4 – удаленного вызова процедур (RPC). Он позволяет серверу удаленно вызывать функции, исполняющиеся на одном или нескольких клиентах. Использование RPC при изменении состояний во время игры ограничивает затраты производительности кадром, в котором происходит изменение. Такая модель «пушей» намного эффективнее. Недостаток в том, что дизайнерам и инженерам приходится более внимательно рассчитывать, где стоит использовать RPC и вызывать возможное переподключение. Несмотря на это, в большинстве случаев замена реплицированных переменных на RPC увеличила производительность в 100–10 000 раз!
Анимация требовала больших ресурсов сервера. Чтобы корректно определить попадание, нужно воспроизводить на сервере те же анимации, которые воспроизводятся на стороне клиентов. Попадания в VALORANT определяются с помощью сохранения позиции и состояния анимации игрока в буфере. Когда сервер получает от клиента пакет данных о выстреле, он восстанавливает позицию и анимацию игрока из буфера, чтобы рассчитать попадание. Изначально мы обрабатывали анимацию и заполняли буфер для каждого кадра. Но после тщательного тестирования мы выяснили, что можно делать это лишь для каждого четвертого кадра, а при восстановлении использовать линейную интерполяцию (lerp) сохраненных анимаций. Это позволило уменьшить затраты производительности на 75%.
Кроме того, мы выяснили, что производительность сервера – это самая важная часть производительности в целом. Представьте, что сервер VALORANT обрабатывает около 150 игр. В любой момент времени около 50 игр будут в фазе покупок. Когда игроки покупают снаряжение, они находятся в безопасной зоне и не могут получить урон сервера. А значит, можно просто отключить анимации на сервере! Что мы и сделали. Со стороны сервера во время фазы покупок игроки неподвижны. Затраты на анимацию в каждом раунде уменьшились на 33%!
Красный контур – неподвижный хитбокс сервера, синий – хитбокс клиентаТеперь вы знаете, как мы оптимизируем код. Но производительность не ограничивается кодом. Важна ещё и платформа, на которой все работает. Давайте обсудим то, что ещё вызывало серьёзные проблем производительности — операционная система и железо.
Чтобы выяснить, как будет вести себя игра в реальном мире, нужно было провести нагрузочное тестирование. Мы хотели выяснить, как физический сервер справится с обработкой более 100 виртуальных серверов на одном ЦП. Это тестирование было критически важно для успешного запуска VALORANT. Мы смогли точно определить, сколько ядер нужно на одного игрока, и устранить ряд ошибок, которые мы не увидели бы без большой нагрузки на сервер. Все оказалось сложнее, чем 7.8 мс в 3 играх на ядро.
Давайте сначала посмотрим на этот график. По оси X – число виртуальных серверов, по оси Y – время обработки кадра.
При единственном сервере мы имеем отличное значение 1,5 мс. Но для 168 серверов время увеличивается до 5,7 мс.
Чтобы понять, почему это происходит и как мы с этим справились, сначала нужно взглянуть на архитектуру современных ЦП.
На изображении вверху можно заметить, что каждое ядро имеет собственную кэш-память L1 и L2, но большой кэш L3 разделен между ядрами. Если на стороне хоста работает единственный сервер, он хранит весь кэш L3, что приводит к меньшему числу ошибок, потому что ядру ЦП требуется меньше времени на ожидание запроса памяти. Поэтому в сценариях с низкой нагрузкой наши серверы работали быстро, но с распределением кэша на большее число виртуальных серверов они замедлялись. Мы с командой специалистов по облачным вычислениям Intel провели некоторые измерения, убедились, что температура и другие значения остаются приемлемыми, и сосредоточились на производительности кэша.
К счастью, у Intel были полезные инструменты измерения и анализа. Мы все еще пользовались более старыми процессорами Intel Xeon E5 с инклюзивной организацией кэш-памяти. Это означает, что все данные в кэше L2 должны присутствовать и в кэше L3. Если данные удаляются из кэша L3, они также удалятся из кэша L2! Получается, что хотя каждый раздел кэша L2 находится на отдельном ядре, на некоторых ядрах кэш L2 мог очиститься, если данные удалялись из кэша L3.
Неприятно, не так ли? В процессорах Intel Xeon Scalable используется неинклюзивная кэш-память, и на них такой проблемы нет. Мы перешли на эти процессоры и значительно увеличили производительность серверных приложений. Последствия разногласий на третьем уровне кэш-памяти еще остались, но производительность увеличилась где-то на 30% при той же частоте ядер.
Мы хотели, чтобы серверы работали еще быстрее. Давайте разберем еще одну особенность архитектуры современных процессоров: неравномерную память (NUMA). Серверы часто двухсокетные. Каждый сокет обеспечивает доступ к участку оперативной памяти системы и передает данные друг другу через общее соединение. Это увеличивает пропускную способность памяти (соединений вдвое больше), но взаимное соединение может стать «бутылочным горлышком». На последней схеме показана упрощенная двухпроцессорная архитектура NUMA. Вот бы операционная система могла выделять память и ресурсы ЦП на уменьшение потока данных через взаимное соединение.
Оказывается, многие современные ОС совместимы с NUMA и могут выполнять такие операции. Например, на Linux это можно сделать с помощью утилиты numactl. Мы переключаем процессы на сервере между нодами таким образом:
Эта небольшая оптимизация использования архитектуры увеличила производительность примерно на 5%. Доступ к памяти NUMA-узлов увеличился с 50% до 97-99%. В дополнение к этим 5%, виртуальные серверы стали работать намного стабильнее!
Во время мониторинга сервера игры мы заметили интересную особенность: ядра бывали загружены на 90–96%, но никогда не нагружались на 100%, даже при загрузке количества игр, вдвое превышающего предполагаемый максимум для сервера. Мы предположили, что причина может быть в планировщик. С помощью инструмента мониторинга процессов Adaptive Optimization от Intel и Linux-утилиты perf мы стали разбираться в проблеме. Linux также дает возможность увидеть исходный код планировщика.
Мы выяснили, что современные системы Linux используют планировщик Completely Fair Scheduler (CFS). Это очень хорошая и оптимизированная программа. Например, она назначает процессы на одно ядро и не дает им мигрировать и запускаться на других ядрах. Это делается для того, чтобы процессы использовали ещё «горячие» линии кэша. Также простаивающие ядра не задействуются без необходимости. Процесс ожидает поступления на занятое ядро в течение некоторого времени, прежде чем CFS разрешит ему обработаться на другом свободном ядре. Значение этого времени ожидания по умолчанию на нашем дистрибутиве Linux было равно 0.5 мс.
Для VALORANT 0.5 мс это слишком долго, учитывая нашу цель в 2.34 мс. За это время можно обработать почти 1/4 кадра! Ни на одном из участков памяти сервера к этому времени не останется горячего кэша. Когда один сервер игры простаивает между кадрами, остальные серверы используют кэш по-максимуму. Если уменьшить время ожидания миграции процессов до 0, планировщик немедленно задействует игровой сервер на любом доступном ядре системы. Так мы рациональнее используем ресурсы ЦП для работы системы и увеличиваем производительность на 4%. Кроме того, мы заметили, что теперь время простоя отдельных ядер уменьшилось почти до нуля!
Также мы контролируем состояние сна (C-режим, или C-State), в которое может входить процессор. Многоядерный процессор позволяет ядрам пребывать в различных режимах энергопотребления. При низкой загрузке ядра часто входят в C-режим для снижения потребления энергии. При увеличении загрузки им требуется время, чтобы вернуться к более активному состоянию. В системах с цикличной нагрузкой, таких, как игровые серверы, ЦП начинает часто переключать C-режимы. У каждого переключения есть задержка, и это снижает производительность. Мы ограничили сон до менее глубоких состояний (C0, C1 и C1E) и смогли стабильно обрабатывать еще 1–3% игр. В итоге была оптимизирована производительность 60–90% загруженных серверов, у которых раньше при уменьшении нагрузки ядра часто простаивали.
Гиперпоточность — это технология архитектуры ЦП, при которой одно физическое ядро может выполнять два потока одновременно. При гиперпоточности части ядра могут вместе использоваться для некоторых процессов (как кэш), а иногда дублироваться (как отдельные вычислительные ядра).
Все зависит от конкретного процессора. В начале разработки у нас было 25 мс на кадр, а отключение гиперпоточности снизило время обработки кадра до 20 мс. Производительность увеличилась на 25%! Но наши друзья из Intel отнеслись к этому скептически. С учетом нашей загрузки мы могли задействовать больше ресурсов оборудования, если бы использовали виртуальные ядра гиперпоточности. Мы прислушались, снова включили гиперпоточность и опять увеличили производительность на 25%.
Как это произошло? Процессоры Intel Xeon Scalable позволили улучшить производительность кэш-памяти и гиперпоточности. Также мы настроили планировщик, чтобы рациональнее использовать доступные ядра, запретили C-режимы глубже C1E для меньшей задержки производительности ядер и приняли другие меры по оптимизации. Мы уменьшили время обработки кадра сервером и достигли гораздо лучших результатов, чем наша изначальная цель в 7,8125 мс.
Нужно учитывать, что производительность каждого приложения различна. Даже то же самое приложение может требовать других ресурсов годы спустя. Поэтому нужно создать воспроизводимые тесты и измерять.
Если просто составить список "способов улучшить производительность", о которых вы узнали, скажем, из блога разработчиков игр, и использовать эти способы без учета особенностей своего приложения, вы можете не только не увеличить производительность, но и уменьшить ее.
В играх часто отмечается прохождение времени. Это делается с помощью системных запросов к ОС через источник времени. ОС, работающая на низкоуровневом окружении (как AWS), может использовать виртуальные источники времени, но они менее производительны. Мы сначала пользовались источниками времени Xen от одноименного гипервизора на нодах AWS. Затем мы переключились на tsc, инструмент из инструкции к ЦП rdtsc, и смогли увеличить производительность игровых серверов на 1–3%.
Приближалась дата релиза, и мы заметили, что один из нагрузочных тестовых серверов менее производителен, чем другие. Железо было идентичным, единственная разница была в том, что он обрабатывал полностью развёрнутое приложение. Нагрузочные тесты показывали в 2–3 раза больше задержек и замедлений кадров, чем на оборудовании, которое я настроил вручную. Мы все проверили – и гипервизор AWS, и различия в конфигурации, и даже исправность оборудования. Все было в порядке.
Мы догадались снова проверить диспетчер Linux с помощью perf shed, чтобы посмотреть, нет ли разницы в процессах. И обнаружили, что каждые 5 секунд запускались 72 процесса: от scheduler_1 и до scheduler_72. По одному на каждое виртуальное ядро. Они сразу же занимали все ядра, предназначенные для серверов игры. Это приводило к постоянным задержкам на загруженных серверах. Оказалось, что наш инструмент для развертывания Mesos использовал для метрики Telegraf, а он делал DNS-запросы каждые 5 секунд. Вызывалось приложение dcos_net, написанное на Erlang.
В Erlang можно настроить количество потоков, которое может обрабатывать диспетчер. Значение по умолчанию – один поток на ядро, отсюда те самые 72 процесса. Мы установили более оптимальное значение 4, и проблема сразу же решилась. Мораль такова: очень важно измерять производительность в той конфигурации, которая совпадает с рабочей средой!
Не увидеть за деревьями леса – очень легко. Даже в этом кратком рассказе о нашем увеличении производительности очень много технических подробностей. В мелких деталях, инструкциях и хитрых способах легко запутаться.
Нужно постоянно оценивать и пересматривать задачи производительности. В эти процессы должна быть вовлечена целая команда, которая всегда поможет в нужный момент.
Оптимизация кода – важная часть производительности, но нужно разделить производительность приложения на отдельные категории и не забывать об окружении (оборудовании и операционной системе). Тогда ваше приложение будет работать максимально эффективно.
Измерения прежде всего! Именно благодаря измерениям мы смогли определять требуемые ресурсы оборудования с погрешностью не более 1%. Поэтому запуск прошел успешно, а вы играете в VALORANT на серверах с тикрейтом 128!
VALORANT — командный тактический шутер от первого лица, выпущенный Riot Games. Сейчас в игре начался Акт 3, с которым в игру была добавлена новая карта Icebox, а 28 числа выйдет новый агент Skye!
А если вам интересно узнать больше о разработке VALORANT, то можете ознакомиться с нашими статьями:
Вышедшая Valorant в начале 2020 году покрыла все сети интернета своей рекламой которая настолько надоедлива, что и я решил попробовать данный бесплатный онлайн шутер создателей (League of Legends).
Создавать проект решили на основе всей известной (Counter Strike Global Offensive), то есть шутер создавался ориентированный на киберспорт, вот только весь "Киберспорт" в игре рушит те же герои которые попросту не сбалансированы. За счет чего в игре уже сформировалась мета персонажей - (То есть тех кого берут, и на тех кого никогда не берут).
Но давайте перед тем как говорить о мете, разберем в целом все остальные гемплейные моменты, так и другие игровые аспекты.
Графика
Разработчики решили сделать максимально простую графику ради большего охвата аудитории, вот только за счет этого она попросту отвратна и после часа игры в Valorant начинают болеть глаза.
Текстуры смотря размыто, и порой такое чувство что одна текстура натянута чуть ли не на одну карту целиком, такое качество не приемлемо.
Я не вижу ничего плохого в подобном стиле, например тот же Overwatch смотрится в разы лучше, детализирование и насыщение, так же играя в overwatch глаза устают куда меньше.
Конечно в игре главное не графика и качество текстурок но не упомянуть данный аспект игры я не мог.
Геймплей
Геймплей сделан на основе Counter Strike Global Offensive, так что я не буду объяснять основы вроде (Две команды, одна ставит бомбу, другая пытается её обезвредить), давайте лучше разберем разные другие детали которые по итогу и составляют саму игру.
Стрельба
Стрельба в Valorant практически на 95% копируют стрельбу из Counter Strike, вот только если в Counter Strike можно стрельба как от бедра и убивать противников, то в Valorant единственный правильный тип стрельбы это по пульке, ибо зажимом стрелять невозможно. За счет такой стрельбы делать вантапы (Один выстрел = одно убийство) очень просто и каждое 2 убийство делается в голову. Это и есть те самые 5% изменений стрельбы в игре.
Остальное, а точнее спрей - (разброс пуль) в игре полностью копирует Counter Strike.
Некоторые профессиональные игроки ещё утверждают что спрей в Valorant рандомен, но это уже я не могу подтвердить.
Диего " Diegosaurs " Раймонд Наварретт — стример TSM
"Я не преувеличиваю, когда называю спрэй паттеры в Valorant худшими их тех, что я когда-либо видел в шутерах (ИМХО). Полный RNG после первых 5 выстрелов и невозможность перенести спрей опускает планку скилла для игроков, которые любят контролировать отдачу вроде меня."
Теперь идём дальше.
Передвижение
В сравните с Counter Strike персонаж в Valorant чувствуется очень тяжелым и медленным как улитка, несмотря на то что можно звять нож в руку и двигаться чуть быстрее, этого не хватает, персонажа все равно чувствуется очень вязко, и медленно будто улитка.
Так же на игре не идет на пользу то что после попадания по персонажу он попросту не может передвигаться (причем в CS:GO работает таже самая система вот только персонаж там не так сильно застревает на месте после попадания), а это значит что в 70% случаях если в вас попали одной пулей, то вы не сможете убежать за угол, за счет чего конечно же вы умерете.
Всё это в совокупности попросту неудобно.
Персонажи
Иван, wot, wows ,Диабло, Старкрафт 2, Раст ( правда только на серверах без eac),underloards и Хренова куча игр. Главное чтобы eac там не было. Ах да CS go, Team fortress и тд
Иван, могу добавить для полного понимания, на linux не идут пока онлайн игры использующие доп прогу античит.
Константин, warface не запускается, из-за античита, насколько мне известно
Лига легенд до сих пор не запускается нормально на линуксе, Валорант тоже, Soulworker тоже
Я вот в основном тольков сетевые играю жанр сурвайвл песочницы по типу майнкрафта, такие как арк, хартворлд, эмпирион галактик сурвайвл, спейс инженерс, мисрейтед, как они ведут себя на линуксе интересно? Кстати очень жаль но кроссаут не запустился на линуксе ибо грёбанный изи античит не пропускает вайн увы
Алексей, у них плохой порт говорят, по сравнению с виндой. смотрел на ютубе сравнения с виндой, где в линуксе значительные просадки на нативном порте.
Но делать это надо будет с самого начала - на чистой только установленной системой с последующей установкой всего необходимого для запуска софта (зависимости, те же, например). Чтобы люди понимали какой путь нужно проделать с момента установки системы до момента успешного запуска игры. Это будет объективно.
Можно было бы на этом закончить, но в приличном обществе всё же нужно аргументировать свою точку зрения.
Тут уже был указан пример, что всё вполне играется… Но что если вам нет дела до самого топового железа и уж тем более лень бороться за каждый кадр? Есть вариант! Вы конечно не выжмите из своего ПК все все соки, зато не просидите ночи напролёт над конфигами.
Вот скриншот моего рабочего стола, несколько иконок слева как бы намекают, играть можно.
Сейчас не 2006 и в зоопарке Линукс-дистрибутивов появилось достаточно представителей, которые не будут от вас требовать огромных знаний, чтобы взаимодействовать с ними. Мой выбор пал на Ubuntu.
Почему?
Выбор операционной системы для домохозяек избавит вас от лишней возни с драйверами (драйвера nVidia теперь поставляются вместе с дистрибутивом, а Радеон и так имеет свои драйвера в составе ядра Linux). Также нет необходимости вспоминать домашние страницы ваших любимых месседжеров — они все есть в центре приложений Ubuntu (и Steam между прочим тоже). Всё очень просто.
(Если вам нужно просто посещать сайты, слушать музыку (Spotify тоже в центре приложений доступен) и играть. Эта страшная штука вам не понадобится.)
Обновления системы посреди игры.
Случаев огромное количество, чтобы назвать это случайностью. Windows нет дела до ваших планов, когда ей нужно обновиться.
С Ubuntu будьте уверены, что этот парень подождёт в сторонке, пока вы не обратите на него внимания. Более того, даже если вы запустите сейчас обновление, система пойдет обновляться и не помешает вышей текущей работе. Вполне возможно даже перезагружаться не потребуется, всё уже подцепилось. Ну и на перезагрузке, если это нужно, она не настаивает. Ребутнётесь, когда вам будет удобно.
Игры в Steam
Начнём с того, что в стиме огромное количество игр нативно работающих на Linux.
Но что нам делать, если у игры нет нативной версии? Без паники! Дядюшка Габен всё предусмотрел. Всё что нужно сделать, это включить одну единственную настройку:
Ставим галочки и всё остальное сделает команда Габена.
Жизнь вне библиотеки Steam
Таким образом у нас есть связь с тиммейтами, у нас есть Steam. И мы уже не боимся, что обновления прервут нашу катку. А как погонять Лигу или отправится покорять мир Военного ремесла? Всё очень просто. Вы уже видели ярлыки Лиги и Варкрафта на скриншоте моего рабочего стола. Я вас уверяю, мне не понадобилось ничего настраивать и красноглазить. На выручку нам приходит сообщество, которое уже всё сделало до нас. Lutris позволяет использовать уже готовые скрипты установки для игр. Всё что вам нужно, это скачать его клиент и установить его (двойной клик по скачанному файлу, а дальше система подскажет). Всё, теперь можно прямо на сайте выбирать интересующую вас игру и кликать Install. Браузер сам вызовет клиент на вашем ПК, сам передаст скрипт, вам останется лишь кликать «далее». После чего можно как создать ярлык, так и запускать игру непосредственно из Lutris.
Дополнительно
Хочешь стримить? Пожалуйста, в центре приложений есть OBS. А может потом ролик смонтировать? Глянь вот сюда:
Вся эта прелесть уже давно нативно есть под linux
Вывод
Итак, мой дорогой читатель, У нас есть связь, у нас есть игры, у нас есть всё, чтобы записать свои похождения и выложить на Youtube. И мы ни разу не использовали страшную и ужасную командную строку (терминал, если по-нашему). В 2020 году, чтобы Попрощаться с BSOD и бесконечными апдейтами в самый неподходящий момент, достаточно уметь нажимать кнопку «далее». Тяжело ли в 2020 году играть на linux? Нет, не тяжело. До свидания.
Читайте также: