Настройте Nginx на Ubuntu за поточно предаване на живо HLS видео

Настройте Nginx на Ubuntu за поточно предаване на живо HLS видео

HTTP Live Streaming (HLS) е много стабилен протокол за поточно видео, реализиран от Apple Inc. HLS използва HTTP транзакции, които преминават през защитни стени, прокси сървъри и могат да бъдат разпространявани чрез CDN с лекота. Следователно тази технология е в състояние да достигне до много по-голяма зрителска аудитория от RTP или други базирани на UDP протоколи. Голяма част от поточно видео на живо онлайн днес се хоства от скъпи системи, които използват HLS, но като цяло са скъпи и изискват много сървърни ресурси. Този урок ще ви покаже как да настроите Ubuntu 14.04 VULTR VPS на много достъпна цена, за да правите HLS поточни събития на живо, като използвате само софтуер с отворен код.

Първата стъпка е да прочетете и настроите вашия сървър според Vultr Doc „ Настройка на Nginx-RTMP на Ubuntu 14.04 “. Инструкциите в този документ бяха най-изчерпателните за етапа на настройка към момента на писане. Бих споменал, че може да пожелаете да замените "nginx-1.7.5" с "nginx-1.9.4" или каквато и да е най-новата версия на Nginx, която е налична. Другото предложение е да компилирате Nginx с модула за състояние на HTTP stub, за да си дадете възможността да наблюдавате колко зрители на живо HLS имате по-късно.

Вместо да компилирате с:

./configure --with-http_ssl_module  --add-module=../nginx-rtmp-module-master

Използвайте този низ в процедурата, описана в документа с предпоставките:

./configure --with-http_ssl_module --with-http_stub_status_module --add-module=../nginx-rtmp-module-master

Примерът в този урок ще създаде както "живи", така и "мобилни" (оптимизирани) потоци и ще използва ffmpeg (инсталиран в предишния урок) за генериране на коригирания с битрейт, оптимизиран за мобилни устройства HLS поток. Примерът също така ще покаже как да накарате сървъра да записва автоматично вашите потоци на живо и да ви позволи да възпроизвеждате записите като услуга за възпроизвеждане на видео при поискване (VOD).

Първо, създайте структурите на папките, необходими за съхраняване на живите и мобилни HLS манифести и видео фрагменти:

sudo mkdir /HLS
sudo mkdir /HLS/live
sudo mkdir /HLS/mobile
sudo mkdir /video_recordings
sudo chmod -R 777 /video_recordings

Вероятно е добра идея да включите защитната си стена, ако още не сте го направили. Ако е така, трябва да разрешите трафик към портовете, използвани от Nginx и HLS. Ако засега искате да работите без защитната стена, игнорирайте раздела ufw по-долу.

sudo ufw limit ssh
sudo ufw allow 80
sudo ufw allow 1935
sudo ufw enable

HLS стрийминг изисква значително различна конфигурация на Nginx от конфигурацията на RTMP в първата статия. Редактирайте nginx.confфайла си, за да използвате следното, като замените "my-ip" и "my-stream-key" с вашата информация. Можете да използвате всичко, което искате за "my-stream-key", това е просто дума, която е уникална и полезна за вас. Може да искате първо да архивирате оригиналния си конфигурационен файл, след което да поставите предоставената от мен информация за конфигурация в редактора, като замените всичко, което беше там:

sudo cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf.original
sudo nano /usr/local/nginx/conf/nginx.conf

Нов nginx.conf:

worker_processes  1;
error_log  logs/error.log debug;
events {
worker_connections  1024;
}
rtmp {
server {
listen 1935;
allow play all;

#creates our "live" full-resolution HLS videostream from our incoming encoder stream and tells where to put the HLS video manifest and video fragments
application live {
allow play all;
live on;
record all;
record_path /video_recordings;
record_unique on;
hls on;
hls_nested on;
hls_path /HLS/live;
hls_fragment 10s;

#creates the downsampled or "trans-rated" mobile video stream as a 400kbps, 480x360 sized video
exec ffmpeg -i rtmp://192.168.254.178:1935/$app/$name -acodec copy -c:v libx264 -preset veryfast -profile:v baseline -vsync cfr -s 480x360 -b:v 400k maxrate 400k -bufsize 400k -threads 0 -r 30 -f flv rtmp://192.168.254.178:1935/mobile/$;
}

#creates our "mobile" lower-resolution HLS videostream from the ffmpeg-created stream and tells where to put the HLS video manifest and video fragments
application mobile {
allow play all;
live on;
hls on;
hls_nested on;
hls_path /HLS/mobile;
hls_fragment 10s;
}

#allows you to play your recordings of your live streams using a URL like "rtmp://my-ip:1935/vod/filename.flv"
application vod {
play /video_recordings;
}
}
}


http {
include       mime.types;
default_type  application/octet-stream;

server {
listen 80;
server_name 192.168.254.178;

#creates the http-location for our full-resolution (desktop) HLS stream - "http://my-ip/live/my-stream-key/index.m3u8"      
location /live {
types {
application/vnd.apple.mpegurl m3u8;
}
alias /HLS/live;
add_header Cache-Control no-cache;
}

#creates the http-location for our mobile-device HLS stream - "http://my-ip/mobile/my-stream-key/index.m3u8"        
location /mobile {
types {
application/vnd.apple.mpegurl m3u8;
}
alias /HLS/mobile;
add_header Cache-Control no-cache;
}   

#allows us to see how stats on viewers on our Nginx site using a URL like: "http://my-ip/stats"     
location /stats {
stub_status;
}

#allows us to host some webpages which can show our videos: "http://my-ip/my-page.html"     
location / {
root   html;
index  index.html index.htm;
}   
}
}

Натиснете Ctrl + X, за да излезете. Кажете „да“, за да запазите промените.

Можете да намерите ясни инструкции и примери за възможните променливи в този nginx.confфайл, ако потърсите в любимата си търсачка „nginx-rtmp директиви“. Използвам nginx-rtmp с HLS от няколко години, без да използвам директивите "разрешаване на публикуване" и "отказване на публикуване" и не съм виждал нулеви случаи на хора да използват/нападат моите видео сървъри. Така че не включих тези директиви тук. Прочетете и добавете тези директиви, ако желаете.

След като промените nginx.confфайла, трябва да рестартирате Nginx, за да използвате новата конфигурация:

sudo service nginx restart

Следете внимателно за съобщения за грешки в Nginx и се справете с всички грешки, които може да са били причинени от неправилно изписване, собственост на папка или проблеми с разрешенията. Ако нямате съобщения за грешка, тогава сте готови да създадете своя поток за кодиране.

Трябва да имате видео енкодер, за да създадете потока. Използвам OBS (Open Broadcaster Software) - който е с отворен код и работи добре за мен. Има и други решения, от които да избирате, които са извън обхвата на този урок. Няма да обхващам всичко за конфигурирането на RTMP видео енкодер. Всички те обаче изискват приблизително еднакви входни променливи. Основните настройки, които ще трябва да въведете, за да използвате моята точна nginx.confконфигурация и да функционирате добре в повечето плейъри/браузъри/платформи, са както следва:

  1. Кодер-x264
  2. Променлив битрейт (не CBR или постоянен битрейт), най-високо качество
  3. Максимална скорост на предаване - 600 kbps
  4. Аудио-кодек-AAC
  5. Аудио-формат-44.1khz
  6. Аудио-битрейт-64kbps
  7. URL адрес на FMS-"rtmp://my-ip:1935/live"
  8. Ключ за поток-"my-stream-key"
  9. Резолюция-640x480
  10. FPS (кадъра в секунда)-30
  11. CFR (постоянна честота на кадрите) - Да
  12. Интервал между ключови кадри-2 секунди (един ключов к��дър на всеки 2 секунди)
  13. x264 Encoding Profile-baseline (може да работи с основния - зависи от използвания плейър)
  14. x264 CPU Присъства - много бърз

Препоръчвам да изпробвате различни енкодери и да експериментирате с тях. Може да желаете широко пропорционално съотношение или вашата камера (или други излъчвани) материали може да го изискват. Ако е така, не забравяйте да промените тази информация във вашия енкодер, както и съотношението, посочено в секцията exec-ffmpeg на nginx.confфайла, който предоставих; в противен случай ще получите някои глупаво изглеждащи видео емисии.

След като вашият енкодер е настроен, можете да тествате всичко. Стартирайте енкодера с вашата уеб камера или някакъв вид тест-фураж, работещ върху него. Можете да видите своето излъчване в този момент с VLC плейър, като използвате URL адреси като:

http://my-ip/live/my-stream-key/index.m3u8
http://my-ip/mobile/my-stream-key/index.m3u8

These are for your main and your mobile video streams, respectively. Substitute your IP and stream key accordingly.

After you've successfully broadcasted your first stream check (via ssh or ftp) that your live broadcast was recorded in the /video_recordings folder on your Vultr VPS. You can also try playing this recorded file in VLC with a URL like:

rtmp://my-ip/vod/filename.flv

Nginx stats are also available (with Nginx stub_status). To view visitor/viewer stats, access:

http://my-ip/stats

In order to view your video on a webpage you'll need an embeddable player. There are many embeddable players available which will play HLS video. I have used JW Player for some years now, but the free version will not play HLS. Flowplayer and Bitdash by Bitmovin (among other solutions) are generous enough to offer a non-commercial version of their players for free which will render your HLS stream embedded in a webpage. For this article, I have tried them both and found them both to work quite well with my Vultr/Nginx-based video server. I will briefly show how I got Flowplayer going with my testbed machine.

Ако ще използвате HLS стрийминг на живо по някакъв редовен, продължителен или комерсиален начин, бих ви насърчил да закупите лиценз от Flowplayer или който и да е плейър, който решите да използвате. Ще получите играч, който има по-малко ограничения, повече функции и може да бъде брандиран за вашата организация. Ще получите и подкрепа - което може да бъде много важно. Освен Vultr VPS, това наистина е единствената цена, свързана с проекта.

Преди да направите каквото и да е друго, важно е да се погрижите за това, което се нарича "крос-домейн" ограничения, които иначе биха изключили способността ви да предавате поточно към уеб страница/уебсайт. Създайте crossdomain.xmlфайл във вашата nginx/htmlпапка и поставете инструкции в него, за да позволите на данните да преминават между домейни:

sudo nano /usr/local/nginx/html/crossdomain.xml

Първо копирайте (от тази страница) и след това поставете (щракнете с десния бутон) в полето на нано редактора следните XML данни:

<?xml version="1.0"?>
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
<cross-domain-policy>
<allow-access-from domain="*"/>
</cross-domain-policy>

Натиснете Ctrl + O, за да изпишете, след това Ctrl + X, за да запишете файла на диск и да излезете.

Взех HTML5 (версия 6.0.3) на Flowplayer, който ми даде редица файлове и папка при разархивиране. Качих всички файлове и папката в подпапка на основната папка на Nginx/HTML, която нарекох "flowplayer". Точният път беше /usr/local/nginx/html/flowplayer.

За да тествате нашето видео, когато е вградено в уеб страница, създайте няколко HTML файла в корена на папката Nginx/HTML с помощта на nano и ги попълнете със следното съдържание.

файл:

sudo nano /usr/local/nginx/html/hls.html

HTML код:

<!doctype html>
<head>
<link rel="stylesheet" href="#">
</head>

<body>
640x480 664kbps (live) Desktop Browsers<br>
<div style="width:640px;" class="flowplayer" data-swf="flowplayer/flowplayer.swf" data-ratio="0.75">
<video>
<source type="application/x-mpegurl" src="">
</video>
</div>
<br><br>
480x360 464kbps (mobile) Mobile Browsers <br>
<div style="width:480px;" class="flowplayer" data-swf="flowplayer/flowplayer.swf" data-ratio="0.75">
<video>
<source type="application/x-mpegurl" src="">
</video>
</div>
</body>

файл:

sudo nano /usr/local/nginx/html/hls_progressive.html

HTML код:

<!doctype html>
<head>
<link rel="stylesheet" href="#">
<style> .flowplayer { width: 640px; } </style>
</head>

<body>
<div class="flowplayer" data-swf="flowplayer/flowplayer.swf" data-ratio="0.75">
<video>
<source type="application/x-mpegurl" src=""> 
<source type="application/x-mpegurl" src="">
</video>
</div>
<br>
</body>

Не забравяйте да замените "my-ip" и "my-stream-key" с вашите данни.

Трябва да замените пътя flowplayer/skin/functional.cssза знака "#" в таблицата със стилове href="#". Учебният софтуер премахва пътя. Трябва да попълните URL в src=""частта - той се премахва от софтуера за обучение, използвайте http://my-ip/live/my-stream-key/index.m3u8и http://my-ip/mobile/my-stream-key/index.m3u8съответно. Вие също трябва да добавите скриптови srcтагове в главата и за двете jquery-1.11.2.min.jsи за flowplayer.min.js. Таговете се премахват от софтуера за обучение. Можете да намерите как да example htmlоформите тези етикети, като разгледате файла, включен в комплекта Flowplayer.

Стартирайте енкодера с вашата уеб камера или някакъв вид тест-фураж, работещ върху него. Можете да гледате излъчването си в браузър, като използвате следните URL адреси:

http://my-ip/hls.html
http://my-ip/hls_progressive.html

Първата страница просто показва всеки един от вашите потоци – основният и този на мобилната платформа. Ще можете да стартирате и двете и да ги видите. Ще забележите, че потокът на мобилната платформа е с по-малък размер. Тези стъпки са само за да се уверите, че всичко работи.

Втората страница показва единичен поток. Но той е настроен по начин, който се нарича "прогресивен стрийминг". Това означава, че когато зрител възпроизвежда видеоклипа, както сървърът, така и плейърът се опитват да дадат на зрителя поток с висок битрейт и високо качество, ако връзката на зрителите може да го издържи. Ако връзката им е лоша и не може да издържи връзката, тя се спуска до показване на потока с по-нисък битрейт (мобилен), който е с 200 kbps по-нисък в честотната лента. Ако желаете, можете да създадете по-степенни, прогресивни потоци с ffmpeg и да ги конфигурирате, като използвате моя пример.

Тествах тази конфигурация на едно ядро, 1GB Vultr VPS и открих, че с един поток на живо, плюс транс-рейтинг мобилен поток, който създава с ffmpeg, използването на процесора беше по-малко от 35% и беше изразходвало само 100MB от моите 1GB RAM. Сега това е много ефективна настройка.

Ако планирате да предавате поточно видео, което е много по-голямо в пикселни размери от SD, може да откриете, че трябва да използвате по-мощен VPS. Бях любопитен за това и пуснах основния си поток до 1280x960 пиксела и 2Mbps - поставяйки допълнително натоварване върху нещата. Но VPS все още използва само 50% CPU и използването на паметта остава на 100MB. Добавих дузина зрители/браузъри и това не направи почти никаква разлика в натоварването на VPS – само използваната честотна лента се увеличи. Сигурен съм, че създаването на допълнителни транс-рейтингови потоци с ffmpeg ще продължи да натоварва системата допълнително.

Използвах този тип сървър в производствена среда с между 50 и 100 едновременни потребители и открих, че използването на ресурсите се е увеличило много малко с увеличаването на връзките на зрителите. Експериментирайте с него. Но мисля, че повечето потребители биха били щастливи да използват едноядрен, 1GB VPS. Насладете се на новия си HLS стрийминг сървър!


Създаване на блог на Jekyll в Ubuntu 16.04

Създаване на блог на Jekyll в Ubuntu 16.04

Използване на различна система? Jekyll е чудесна алтернатива на WordPress за блогове или споделяне на съдържание. Не изисква никакви бази данни и е много лесно i

Как да инсталирате Squid Proxy на CentOS

Как да инсталирате Squid Proxy на CentOS

Squid е популярна, безплатна програма за Linux, която ви позволява да създадете уеб прокси за препращане. В това ръководство ще видите как да инсталирате Squid на CentOS, за да ви обърне

Как да инсталирате Memcached на Ubuntu 14.04

Как да инсталирате Memcached на Ubuntu 14.04

Memcached е високопроизводителна система за бази данни, която може да помогне за презареждане на вашето приложение. Много е бърз, тъй като не пише на диска, а вместо това t

Инсталиране на InfluxDB на Ubuntu 14

Инсталиране на InfluxDB на Ubuntu 14

Въведение InfluxDB е с отворен код, разпределена база данни от времеви серии без външни зависимости. Да, вие четете без външни зависимости пар

Настройка на Fail2ban Ubuntu x64

Настройка на Fail2ban Ubuntu x64

Fail2ban е програма, която следи активността за влизане на вашия сървър и блокира нарушаващите IP адреси. По подразбиране той ще блокира IP адресите за 10 минути

Настройте Red5 Media Server на Ubuntu 16.04

Настройте Red5 Media Server на Ubuntu 16.04

Използване на различна система? Red5 е медиен сървър с отворен код, внедрен в Java, който ви позволява да стартирате Flash многопотребителски приложения, като например предаване на живо

Как да инсталирате Vanilla Forum на Ubuntu 16.04

Как да инсталирате Vanilla Forum на Ubuntu 16.04

Използване на различна система? Vanilla forum е приложение за форум с отворен код, написано на PHP. Той е напълно адаптивен, лесен за използване и поддържа външен

Как да инсталирате Kanboard на Ubuntu 18.04 LTS

Как да инсталирате Kanboard на Ubuntu 18.04 LTS

Използване на различна система? Въведение Kanboard е безплатна програма за управление на проекти с отворен код, която е предназначена да улеснява и визуализира

Как да инсталирате Kanboard на Debian 9

Как да инсталирате Kanboard на Debian 9

Използване на различна система? Въведение Kanboard е безплатна програма за управление на проекти с отворен код, която е предназначена да улеснява и визуализира

Как да инсталирате Tiny Tiny RSS Reader на FreeBSD 11 FAMP VPS

Как да инсталирате Tiny Tiny RSS Reader на FreeBSD 11 FAMP VPS

Използване на различна система? Tiny Tiny RSS Reader е безплатен четец и агрегатор с отворен код, самостоятелно хостван уеб базиран новинарски канал (RSS/Atom), предназначен да

Как да инсталирате Gitea на Debian 9

Как да инсталирате Gitea на Debian 9

Използване на различна система? Gitea е алтернатива с отворен код, самостоятелно хоствана система за контрол на версиите, задвижвана от Git. Gitea е написана на Голанг и е

Как да инсталирате Wiki.js на FreeBSD 11

Как да инсталирате Wiki.js на FreeBSD 11

Използване на различна система? Wiki.js е безплатно и модерно уики приложение с отворен код, изградено на Node.js, MongoDB, Git и Markdown. Изходният код на Wiki.js е публичен

Как да инсталирате Gitea на Ubuntu 18.04

Как да инсталирате Gitea на Ubuntu 18.04

Използване на различна система? Gitea е алтернатива с отворен код, самостоятелно хоствана система за контрол на версиите, задвижвана от git. Gitea е написана на Голанг и е

Как да инсталирате Thelia 2.3 на Debian 9

Как да инсталирате Thelia 2.3 на Debian 9

Използване на различна система? Thelia е инструмент с отворен код за създаване на уебсайтове за е-бизнес и управление на онлайн съдържание, написано на PHP. Изходен код на Thelia i

Как да инсталирате Microweber на CentOS 7

Как да инсталирате Microweber на CentOS 7

Използване на различна система? Microweber е CMS и онлайн магазин с отворен код за плъзгане и пускане. Изходният код на Microweber се хоства на GitHub. Това ръководство ще ви покаже

Инсталиране на Microweber на Ubuntu 16.04

Инсталиране на Microweber на Ubuntu 16.04

Използване на различна система? Microweber е CMS и онлайн магазин с отворен код за плъзгане и пускане. Изходният код на Microweber се хоства на GitHub. Това ръководство ще ви покаже

Как да инсталирате MODX Revolution на Ubuntu 16.04 LAMP VPS

Как да инсталирате MODX Revolution на Ubuntu 16.04 LAMP VPS

Използване на различна система? MODX Revolution е бърза, гъвкава, мащабируема, безплатна и отворена система за управление на съдържанието (CMS) от корпоративен клас, написана i

Как да инсталирате Mattermost 4.1 на CentOS 7

Как да инсталирате Mattermost 4.1 на CentOS 7

Използване на различна система? Mattermost е самостоятелно хоствана алтернатива с отворен код на Slack SAAS услугата за съобщения. С други думи, с Mattermost, вие ca

Как да инсталирате dotCMS на Ubuntu 16.04

Как да инсталирате dotCMS на Ubuntu 16.04

Използване на различна система? DotCMS е система за управление на съдържанието от корпоративен клас с отворен код, написана на Java. Той съдържа почти всички необходими функции

Как да инсталирате Pagekit 1.0 CMS на FreeBSD 11 FAMP VPS

Как да инсталирате Pagekit 1.0 CMS на FreeBSD 11 FAMP VPS

Използване на различна система? Pagekit 1.0 CMS е красива, модулна, разширяема и лека, безплатна система за управление на съдържанието (CMS) с отворен код с

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече