RTMP este excelent pentru a servi conținut live. Când RTMP este asociat cu FFmpeg, fluxurile pot fi convertite în diferite calități. Vultr este excelent pentru aceste aplicații, deoarece oferă performanță procesorului rapid și dedicat. Rețeaua globală Vultr vă asigură, de asemenea, că puteți livra conținut live de înaltă calitate, cu întârziere minimă. Să începem!
Instalarea Nginx și Nginx-RTMP
Instalați instrumentele necesare pentru a compila Nginx și Nginx-RTMP de la sursă.
sudo yum install pcre pcre-devel openssl openssl-devel zlib zlib-devel -y
Faceți un director de lucru și treceți la acesta.
mkdir ~/working
cd ~/working
Descărcați sursele Nginx și Nginx-RTMP.
wget http://nginx.org/download/nginx-1.9.7.tar.gz
wget https://github.com/arut/nginx-rtmp-module/archive/master.zip
Instalați pachetul dezarhivat.
sudo yum install unzip
Extrageți sursa Nginx și Nginx-RTMP.
tar -xvf nginx-1.9.7.tar.gz
unzip v1.2.1.zip
Treceți la directorul Nginx.
cd nginx-1.9.7
Adăugați module pentru a compila în Nginx. Nginx-RTMP este inclus.
./configure --add-module=../nginx-rtmp-module-1.2.1/
Compilați și instalați Nginx cu Nginx-RTMP.
make
sudo make install
Creați un fișier unitate SystemD pentru Nginx.
sudo nano /usr/lib/systemd/system/nginx.service
Populați fișierul cu următorul conținut.
[Unit]
Description=nginx - high performance web server
Documentation=https://nginx.org/en/docs/
After=network-online.target remote-fs.target nss-lookup.target
Wants=network-online.target
[Service]
Type=forking
PIDFile=/var/run/nginx.pid
ExecStartPre=/usr/sbin/nginx -t -c /etc/nginx/nginx.conf
ExecStart=/usr/sbin/nginx -c /etc/nginx/nginx.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s TERM $MAINPID
[Install]
WantedBy=multi-user.target
Porniți și activați serviciul Nginx.
sudo systemctl start nginx.service
Spuneți SystemD să pornească automat serviciile Nginx la boot.
systemctl enable nginx.service
Instalarea FFmpeg
Instalați epel-releaseși actualizați sistemul.
sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now
Instalați depozitul Nux.
sudo rpm --import http://li.nux.ro/download/nux/RPM-GPG-KEY-nux.ro
sudo rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
Instalați FFmpeg și pachetele sale de dezvoltare.
sudo yum install ffmpeg ffmpeg-devel -y
Configurarea Nginx-RTMP și FFmpeg
Deschideți fișierul de configurare Nginx.
sudo nano /usr/local/nginx/conf/nginx.conf
Adăugați următoarele la configurație.
rtmp {
server {
listen 1935;
chunk_size 4096;
application live {
live on;
record off;
exec ffmpeg -i rtmp://localhost/live/$name -threads 1 -c:v libx264 -profile:v baseline -b:v 350K -s 640x360 -f flv -c:a aac -ac 1 -strict -2 -b:a 56k rtmp://localhost/live360p/$name;
}
application live360p {
live on;
record off;
}
}
}
După ce ați adăugat textul de configurare, puteți personaliza setările precum un bitrate video, bitrate audio și rezoluție. Aceste modificări se vor aplica numai fluxului de calitate inferioară. Pentru a adăuga mai multe calități, copiați și lipiți linia exec FFmpeg și modificați setările. De asemenea, va trebui să creați o aplicație nouă. Puteți face acest lucru copiind și lipind exemplul live360 care a fost inclus. Nu uitați să actualizați linia exec FFmpeg cu adresa noii aplicații. Puteți face acest lucru schimbând adresa RTMP finală în linia exec FFmpeg.
Notă: Modificarea valorii după -b:vva schimba bitrate video. Aceasta se măsoară în kilobiți pe secundă. Modificarea valorii după -b:ava schimba bitrate audio. Aceasta se măsoară în kilobiți pe secundă. Modificarea valorii după -sva schimba rezoluția.
Salvați fișierul apăsând CTRL+ X.
Reporniți Nginx.
sudo service nginx restart
Notă: Pentru cele mai bune performanțe, fiecare flux convertit ar trebui să aibă propriul nucleu al procesorului. De exemplu, dacă se creează două calități, 360P și 480P, dintr-un flux 720P, ar trebui să se utilizeze o instanță Vultr cu cel puțin două nuclee de procesor.
Notă de securitate
Dacă utilizați un firewall, va trebui să vă asigurați că TCP 1935este permis.
Configurația curentă permite oricui să transmită fluxul către serverul dvs. Putem rezolva acest lucru numai dând anumite adrese IP permisiunea de publicare. Deschideți configurația Nginx.
sudo nano /usr/local/nginx/conf/nginx.conf
Căutați următoarele rânduri.
live on;
record off;
Adăugați următoarele pentru fiecare set de linii de mai sus. Modificați 0.0.0.0adresa dvs. IP reală.
allow publish 127.0.0.1;
allow publish 0.0.0.0;
deny publish all;
Configurația va arăta acum ca cea următoare.
rtmp {
server {
listen 1935;
chunk_size 4096;
application live {
live on;
record off;
allow publish 127.0.0.1;
allow publish 0.0.0.0;
deny publish all;
exec ffmpeg -i rtmp://localhost/live/$name -threads 1 -c:v libx264 -profile:v baseline -b:v 350K -s 640x360 -f flv -c:a aac -ac 1 -strict -2 -b:a 56k rtmp://localhost/live360p/$name;
}
application live360p {
live on;
record off;
allow publish 127.0.0.1;
allow publish 0.0.0.0;
deny publish all;
}
}
}
Salvați fișierul apăsând CTRL+ X.
Reporniți Nginx.
sudo service nginx restart
Configurarea software-ului pentru a funcționa cu Nginx-RTMP
Aplicațiile de streaming au de obicei două câmpuri pentru informații de conectare. Primul câmp este de obicei pentru informațiile despre server și al doilea câmp este de obicei pentru numele fluxului sau cheia. Sunt listate informațiile pe care ar trebui să le introduceți în fiecare câmp. Numele sau cheia fluxului pot fi setate la orice.
Field 1: rtmp://your.vultr.ip/live/
Field 2: stream-key-you-set
Pentru a vizualiza fluxurile, deschideți următoarele legături într-un player care acceptă RTMP.
rtmp://your.vultr.ip/live/stream-key-you-set
rtmp://your.vultr.ip/live360p/stream-key-you-set