Создание среды Nginx + RTMP + nginx-http-flv-module (CentOS 7)
Создание среды Nginx + RTMP + nginx-http-flv-module (CentOS 7)
🎉Создание среды Nginx + RTMP + nginx-http-flv-module (CentOS 7)

1. Введение

Протокол обмена сообщениями в реальном времени (RTMP) — это протокол, предназначенный для передачи данных в реальном времени и широко используемый в потоковых сервисах. В этой статье рассказывается, как создать RTMP-сервер на базе Nginx в CentOS 7 и использовать модуль nginx-http-flv-module для реализации службы потокового мультимедиа HTTP-FLV.

2. Установите nginx

Сначала нам нужно установить Nginx. Установите Nginx на CentOS 7, используя следующую команду:

Язык кода:javascript
копировать
sudo yum install epel-release
sudo yum install nginx

После завершения установки запустите службу Nginx и настройте ее автоматический запуск при загрузке:

Язык кода:javascript
копировать
sudo systemctl start nginx
sudo systemctl enable nginx

3. Установите зависимые библиотеки.

Для поддержки модуля RTMP нам необходимо установить несколько зависимых библиотек:

Язык кода:javascript
копировать
sudo yum install -y pcre pcre-devel zlib zlib-devel openssl openssl-devel

4. Загрузите и скомпилируйте Nginx с модулем RTMP.

Язык кода:javascript
копировать
cd ~
wget http://nginx.org/download/nginx-1.18.0.tar.gz
tar -zxvf nginx-1.18.0.tar.gz
cd nginx-1.18.0

# скачать nginx-rtmp-module
git clone https://github.com/arut/nginx-rtmp-module.git

# компилировать Установить
./configure --add-module=./nginx-rtmp-module
make
sudo make install

5. Настройте Nginx

Редактировать файл конфигурации Nginx /usr/local/nginx/conf/nginx.conf

Язык кода:javascript
копировать
worker_processes  1;

events {
    worker_connections  1024;
}

rtmp {
    server {
        listen 1935;
        chunk_size 4096;

        application live {
            live on;
            record off;

            # добавить в HLS поддерживать
            hls on;
            hls_path /usr/local/nginx/html/hls;
            hls_fragment 3;
            hls_playlist_length 60;
        }
    }
}

http {
    server {
        listen 80;
        server_name localhost;

        location / {
            root   html;
            index  index.html index.htm;
        }

        # добавить в HTTP-FLV модуль Конфигурация
        location /live {
            flv;
            root /usr/local/nginx/html;
        }
    }
}

В конфигурации выше,Определяем RTMP-сервер,Прослушивание порта 1935. в,application live Используется для обработки прямых трансляций, и мы включили поддержку HLS. Служба HTTP прослушивает порт 80, а конфигурация модуля HTTP-FLV добавлена ​​для обработки потоков HTTP в формате FLV.

6. Запустите Nginx

Запустите службу Nginx:

Язык кода:javascript
копировать
sudo /usr/local/nginx/sbin/nginx

7. Push-тест

Используйте инструменты, поддерживающие потоковую передачу RTMP (например, OBS). Studio) для push-тестирования. Установите адрес для отправки rtmp://your-server-ip:1935/live/stream

8. Игровой тест

Для доступа используйте браузер или инструмент, поддерживающий воспроизведение FLV. http://your-server-ip/live/stream.flv Выполните тест воспроизведения.

На этом этапе вы успешно настроили среду службы потокового мультимедиа с помощью Nginx + RTMP + nginx-http-flv-module.

9. Развернуть

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

Вы можете аутентифицировать прямые трансляции через модуль аутентификации Nginx, чтобы предотвратить несанкционированный доступ.

Язык кода:javascript
копировать
location /live {
    flv;
    root /usr/local/nginx/html;
    # Аутентификация Конфигурация    secure_link $arg_hash,$arg_expires;
    secure_link_md5 "$secure_link_expires$uri secret";
    if ($secure_link = "") {
        return 403;
    }
}
9.2 Конфигурация HTTPS

Если вам нужно использовать HTTPS, вы можете настроить его через модуль SSL Nginx.

Язык кода:javascript
копировать
server {
    listen 443 ssl;
    server_name your-domain;

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/private.key;

    location / {
        root   html;
        index  index.html index.htm;
    }

    location /live {
        flv;
        root /usr/local/nginx/html;
    }
}
9.3 Конфигурация безопасности

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

10. Резюме

Из этой статьи вы научились настраивать службу потоковой передачи Nginx + RTMP + nginx-http-flv-module в CentOS 7. Этот метод построения можно использовать в прямых трансляциях, видеоконференциях и других сценариях. Он также поддерживает HTTP-FLV для удобного воспроизведения в браузере. В реальных приложениях можно выполнить дополнительные конфигурации в соответствии с потребностями конкретного бизнеса.

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 и детали кода