利用nginx搭建RTMP視頻點播、直播、HLS服務(wù)器
開發(fā)環(huán)境
- Ubuntu 14.04 server
- nginx-1.8.1
- nginx-rtmp-module
nginx的服務(wù)器的搭建
安裝nginx的依賴庫
sudo apt-get update sudo apt-get install libpcre3 libpcre3-dev sudo apt-get install openssl libssl-dev
配置并編譯nginx
使用nginx的默認(rèn)配置,添加nginx的rtmp模塊。
./configure --add-module=../nginx-rtmp-module-master make sudo make install
運行測試nginx
進(jìn)入安裝目錄/usr/local/nginx,運行命令./sbin/nginx
注意:以后所有的命令都在/usr/local/nginx目錄運行,也nginx配置文件的相對目錄。
打開瀏覽器在地址欄輸入:localhost。如果,如下圖顯示那樣就證明您的nginx服務(wù)器搭建成功了。
點播視頻服務(wù)器的配置
通過上一步nginx服務(wù)器已經(jīng)搭建完成,然后我們就可以開啟一個視頻點播的服務(wù)了。打開配置文件nginx.conf,添加RTMP的配置。
worker_processes 1; events { worker_connections 1024; } rtmp { #RTMP服務(wù) server { listen 1935; #//服務(wù)端口 chunk_size 4096; #//數(shù)據(jù)傳輸塊的大小 application vod { play /opt/video/vod; #//視頻文件存放位置。 } } } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; location / { root html; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
配置目錄*/opt/video/vod*為存放視頻文件的位置了,那我們就往里面放一個文件吧。我放了一個qq.mp4文件。
文件放好之后,那就讓我們重新啟動一下nginx
sudo ./sbin/nginx -s reload
打開視頻播放軟件選用的是VLC media-> open network stream…
如圖填寫我們要點播的節(jié)目地址rtmp://localhost/vod/qq.mp4 如圖:
點擊play就可以播放了。
當(dāng)然點播不使用RTMP插件nginx自身也是可以實現(xiàn)點播服務(wù)的。那就是配置location部分,由于下面我們要配置直播和回看功能所以選用了RTMP服務(wù)。
直播視頻服務(wù)器的配置
接著我們就在點播服務(wù)器配置文件的基礎(chǔ)之上添加直播服務(wù)器的配置。一共2個位置,第一處就是給RTMP服務(wù)添加一個application這個名字可以任意起,也可以起多個名字,由于是直播我就叫做它live吧,如果打算弄多個頻道的直播就可以live_cctv1、live_cctv2名字任意。第二處就是添加兩個location字段,字段的內(nèi)容請直接看文件吧。
worker_processes 1; events { worker_connections 1024; } rtmp { server { listen 1935; chunk_size 4096; application vod { play /opt/video/vod; } application live{ #第一處添加的直播字段 live on; } } } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; location /stat { #第二處添加的location字段。 rtmp_stat all; rtmp_stat_stylesheet stat.xsl; } location /stat.xsl { #第二處添加的location字段。 root /usr/local/nginx/nginx-rtmp-module/; } location / { root html; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
添加完這兩處之后,重新啟動nginx打開瀏覽器看看,是否有如下圖顯示:
有沒有看到紅框框的live字樣呢?如果可以顯示出來,證明你的配置生效了。
還等什么讓我們推送一個節(jié)目看看(其實專業(yè)詞叫錄制,后面將會使用錄制這個詞。)吧。
這次推送我使用的是OBS(Open Broadcaster Software)會給大家介紹如何使用手機采集視頻并且推送到服務(wù)器上。
首先安裝FFmpeg
添加源:
sudo add-apt-repository ppa:kirillshkrogalev/ffmpeg-next
更新源:
sudo apt-get update
安裝:
sudo apt-get install ffmpeg
如果是Ubuntu 15.04可以直接使用
sudo apt-get install ffmpeg
安裝obs-studio
添加源:
sudo add-apt-repository ppa:obsproject/obs-studio
更新源:
sudo apt-get update
安裝:
sudo apt-get install obs-studio
配置OBS如圖:
點擊紅圈添加“Media Source”,會彈出一個框框,里面的內(nèi)容就按照圖片顯示配置就可以了。點擊“OK”就能在你的屏幕上播放了。
配置節(jié)目的輸出流如圖所示:
首先點擊紅圈“setting”進(jìn)入設(shè)置界面。記得要正確填寫要錄制的服務(wù)器路徑啊。配置好就可以點擊OK了。退出后點擊藍(lán)圈,就開始錄制節(jié)目了。
查看我們的了錄制的節(jié)目,服務(wù)器有沒有接收到呢?打開我的服務(wù)器地址“http://localhost/stat”查看一下 ,你的顯示是否和我的相同呢?如果相同證明服務(wù)器已經(jīng)接收到了錄制的節(jié)目,客戶端可以進(jìn)行播放了。
播放的地址就是“rtmp://localhost/live/test”,如果您本地有支持rtmp協(xié)議的播放器就可以試試了。最后奉上一張觀看直播的屏幕截圖。
實時回看視頻服務(wù)器的配置
我們想一想如果直播服務(wù)能夠把節(jié)目錄制在本地,我們不就可以直接進(jìn)行回看先前的節(jié)目了嗎?回看一分鐘、一小時甚至一天的。想想就興奮不用寫代碼有現(xiàn)成的可以使用。怎么用呢?繼續(xù)看nginx的配置吧。
worker_processes 1; events { worker_connections 1024; } rtmp { server { listen 1935; chunk_size 4096; application vod { play /opt/video/vod; } application live { live on; hls on; #這個參數(shù)把直播服務(wù)器改造成實時回放服務(wù)器。 wait_key on; #對視頻切片進(jìn)行保護(hù),這樣就不會產(chǎn)生馬賽克了。 hls_path /opt/video/hls; #切片視頻文件存放位置。 hls_fragment 10s; #每個視頻切片的時長。 hls_playlist_length 60s; #總共可以回看的事件,這里設(shè)置的是1分鐘。 hls_continuous on; #連續(xù)模式。 hls_cleanup on; #對多余的切片進(jìn)行刪除。 hls_nested on; #嵌套模式。 } } } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; location /stat { rtmp_stat all; rtmp_stat_stylesheet stat.xsl; } location /stat.xsl { root /usr/local/nginx/nginx-rtmp-module/; } location /live { #這里也是需要添加的字段。 types { application/vnd.apple.mpegurl m3u8; video/mp2t ts; } alias /opt/video/hls; expires -1; add_header Cache-Control no-cache; } location / { root html; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
1.添加完成后需要重新啟動nginx,由于這次nginx需要向服務(wù)器寫切片視頻文件,但nginx我又沒有給nginx指定用戶名只能走默認(rèn)的nobody用戶和nogroup用戶組,其實就是沒有組。所以我對需要寫入的目錄做了增大權(quán)限的修改。
如下圖,這樣做就是為了避免由于權(quán)限問題而無法寫文件。
2.如何給服務(wù)器錄制視頻,在上一節(jié)已經(jīng)說過,這里就不再說了。
3.查看視頻文件是否真的錄制上沒有,繼續(xù)看圖:
已經(jīng)產(chǎn)生切片視頻文件了。其中還有一個index.m3u8。
4.播放視頻,這次可是http開頭的了,“http://localhost/live/test/index.m3u8”。
5.已經(jīng)可以播放了,如何回看呢?其實這個index.m3u8文件僅僅是目錄。想回看那個就播放那個.ts文件就可以了。
到此這篇關(guān)于利用nginx搭建RTMP視頻點播、直播、HLS服務(wù)器的文章就介紹到這了,更多相關(guān)nginx搭建RTMP視頻點播內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。