Используйте Nginx-RTMP для создания простого сервера потокового мультимедиа.
Используйте Nginx-RTMP для создания простого сервера потокового мультимедиа.

Установить

последовательность

Иногда вы можете столкнуться с подобными сценариями:

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

В это время я подумаю, можно ли четко и плавно разделить экран и видеопоток? Очевидно, что прямая трансляция отвечает этому ряду условий. Итак, вот несколько решений:

  1. использоватьтретья сторонапрямая трансляционная платформа для прямой трансляция
  2. Выбрать существующую прямую потоковый сервис (как Тенсент Облакоиз стандартныйпрямая трансляция LVB )
  3. Если у вас простаивает сервер,Вы можете пуш-стриминг на своем сервере

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

В этой статье рассматривается последний случай,Иметь свой сервер,Надеемся, что он реализует простую прямую трансляцию Push-стриминга.

среда

Выбор развертывания часто определяет конечный результат использования, на этот раз Lighthouse Легкий сервер приложений размещен в дата-центре материкового Китая. В настоящее время самую низкую цену существования обеспечивает Конфигурация. 2 виртуальный CPU, 2 GB память и 4 MB Полоса пропускания в нисходящем направлении.

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

Если вы используете 4000 KBps скорость прямого кода трансляцияPush-стриминг, без конвертации и сжатия кода, может смотреть другой друг, если использовать 2000 KBps Скорость кода, прямая трансляцияPush-стриминг,

Требуемая скорость кода тесно связана с контентом и методом кодирования. Приведем пример и пожалуемся на него. это видео предоставил “1080P «Высокий битрейт» Скорость кода составляет всего 1000 Кбит/с, где скорость передачи видео составляет только 825 Кбпс, разве вам всем не нравится это смотреть? (

Короче говоря, эту статью не следует использовать для настройки конфигурации:

  1. Пакет Tencent Cloud Lighthouse Guangzhou 2022_gen_01 (2 ядра, 2 ГБ памяти, пропускная способность 4 МБ, трафик 300 ГБ)
  2. Операционная система: Ubuntu 22.04.

Быстрая установка

Поиск в Интернете Nginx-RTMP, можно получить много инструкций по компиляции Установить, но на самом деле на данный момент нет необходимости заморачиваться с существующим, просто использовать apt Менеджер пакетов можно использовать через search Найдите пакет, который требует Установить:

результаты поиска apt по nginx rtmp
результаты поиска apt по nginx rtmp

Установить Nginx и Nginx-RTMP, для облегчения перекодирования необходимо дополнительно установить ffmpeg

Язык кода:shell
копировать
# Обновить исходный код программного обеспечения
apt update
# apt upgrade -y

# Установить
apt install nginx libnginx-mod-rtmp -y

# ffmpeg (если требуется перекодирование)
apt install ffmpeg -y

Конфигурация

Посмотреть проект на GitHub

Конфигурациядокумент

Nginx-RTMP из Конфигурация Нужно написатьсуществовать nginx.conf файл, в настоящее время находится в среде /etc/nginx/nginx.conf

Большая часть файлов конфигурации существует. Файлы конфигурации создаются заново. rtmp модуль и напишите, небольшую часть Конфигурации нужно записать в файл Конфигурации. http в модуле.

весь Конфигурацияссылка:https://github.com/arut/nginx-rtmp-module/wiki/Directives

Конфигурация Пример

Видео по запросу

Язык кода:json
копировать
rtmp {
    server {
        listen 1935;
        application vod {
            play /var/document/vedios;
        }
    }
}

прямая трансляция

Язык кода:json
копировать
rtmp {
    server {
        listen 1935;
        application live {
            live on;
        }
    }
}

В разделе «Конфигурация» адрес Push-стриминга: rtmp://IP_ OR_DOMAIN/live/,когдаиспользовать live При выполнении Push-стриминга для кода Push-стриминга игровой адрес имеет вид rtmp://IP_ OR_DOMAIN/live/live

Прямоток

Язык кода:json
копировать
rtmp {
 server{
     listen 1935;
     chunk_size 4096;
     application live {
           live on;
           record off;
           push rtmp://target;
          }
    }
} 

Установите разные ограничения битрейта или перекодируйте

Используйте ffmpeg для выполнения операций перекодирования

Язык кода:json
копировать
rtmp {
    server {
        listen 1935;
    
        application src {
            live on;

            exec ffmpeg -i rtmp://localhost/src/$name
              -c:a aac -b:a 32k  -c:v libx264 -b:v 128K -f flv rtmp://localhost/hls/$name_low
              -c:a aac -b:a 64k  -c:v libx264 -b:v 256k -f flv rtmp://localhost/hls/$name_mid
              -c:a aac -b:a 128k -c:v libx264 -b:v 512K -f flv rtmp://localhost/hls/$name_hi;
        }

        application hls {
            live on;

            hls on;
            hls_path /tmp/hls;
            hls_nested on;

            hls_variant _low BANDWIDTH=160000;
            hls_variant _mid BANDWIDTH=320000;
            hls_variant _hi  BANDWIDTH=640000;
        }
    }
}

Нажми и играй

Push-стриминг

Push-стриминг Можетиспользовать OBS、ffmpeg Подождите инструменты

Примечание: x11захват в новой версии ffmpeg был удален, приведя пример ffmpegPush-стриминга:

Язык кода:shell
копировать
./ffmpeg -f gdigrab -framerate 30 -i desktop -c:v h264\_nvenc -qp 0 -acodec aac -f flv rtmp://IP_OR_DOMAIN:1935/live/live

играть

играть Можетразличными способами,нравиться ffplay, веб-страницы, сторонние клиенты (например, PotPlayer) и т.д.

boy illustration
Учебное пособие по Jetpack Compose для начинающих, базовые элементы управления и макет
boy illustration
Код js веб-страницы, фон частицы, код спецэффектов
boy illustration
【новый! Суперподробное】Полное руководство по свойствам компонентов Figma.
boy illustration
🎉Обязательно к прочтению новичкам: полное руководство по написанию мини-программ WeChat с использованием программного обеспечения Cursor.
boy illustration
[Забавный проект Docker] VoceChat — еще одно приложение для мгновенного чата (IM)! Может быть встроен в любую веб-страницу!
boy illustration
Как реализовать переход по странице в HTML (html переходит на указанную страницу)
boy illustration
Как решить проблему зависания и низкой скорости при установке зависимостей с помощью npm. Существуют ли доступные источники npm, которые могут решить эту проблему?
boy illustration
Серия From Zero to Fun: Uni-App WeChat Payment Practice WeChat авторизует вход в систему и украшает страницу заказа, создает интерфейс заказа и инициирует запрос заказа
boy illustration
Серия uni-app: uni.navigateЧтобы передать скачок значения
boy illustration
Апплет WeChat настраивает верхнюю панель навигации и адаптируется к различным моделям.
boy illustration
JS-время конвертации
boy illustration
Обеспечьте бесперебойную работу ChromeDriver 125: советы по решению проблемы chromedriver.exe не найдены
boy illustration
Поле комментария, щелчок мышью, специальные эффекты, js-код
boy illustration
Объект массива перемещения объекта JS
boy illustration
Как открыть разрешение на позиционирование апплета WeChat_Как использовать WeChat для определения местонахождения друзей
boy illustration
Я даю вам два набора из 18 простых в использовании фонов холста Power BI, так что вам больше не придется возиться с цветами!
boy illustration
Получить текущее время в js_Как динамически отображать дату и время в js
boy illustration
Вам необходимо изучить сочетания клавиш vsCode для форматирования и организации кода, чтобы вам больше не приходилось настраивать формат вручную.
boy illustration
У ChatGPT большое обновление. Всего за 45 минут пресс-конференция показывает, что OpenAI сделал еще один шаг вперед.
boy illustration
Copilot облачной разработки — упрощение разработки
boy illustration
Микросборка xChatGPT с низким кодом, создание апплета чат-бота с искусственным интеллектом за пять шагов
boy illustration
CUDA Out of Memory: идеальное решение проблемы нехватки памяти CUDA
boy illustration
Анализ кластеризации отдельных ячеек, который должен освоить каждый&MarkerгенетическийВизуализация
boy illustration
vLLM: мощный инструмент для ускорения вывода ИИ
boy illustration
CodeGeeX: мощный инструмент генерации кода искусственного интеллекта, который можно использовать бесплатно в дополнение к второму пилоту.
boy illustration
Машинное обучение Реальный бой LightGBM + настройка параметров случайного поиска: точность 96,67%
boy illustration
Бесшовная интеграция, мгновенный интеллект [1]: платформа больших моделей Dify-LLM, интеграция без кодирования и встраивание в сторонние системы, более 42 тысяч звезд, чтобы стать свидетелями эксклюзивных интеллектуальных решений.
boy illustration
LM Studio для создания локальных больших моделей
boy illustration
Как определить количество слоев и нейронов скрытых слоев нейронной сети?
boy illustration
[Отслеживание целей] Подробное объяснение ByteTrack и детали кода