Mac直播服務器Nginx配置對HLS的支持
在上一篇中Mac上搭建直播服務器Nginx+rtmp,我們已經搭建了nginx+rtmp直播服務器。下面需要對Nginx服務器增加對HLS的支持。在Nginx增加對HLS種支持比較簡單,只是簡單的修改下配置文件nginx.conf即可。
安裝 nginx 和 rtmp 模塊
有關 nginx 的編譯和安裝比較簡單,請參考上一篇中Mac上搭建直播服務器Nginx+rtmp。這里提示以下幾點:
(1) 安裝好 nginx 后,打開配置文件:
/usr/local/nginx/conf/nginx.conf
(2) 啟動 nginx 的命令:
$ sudo /usr/local/nginx/sbin/nginx -s stop $ sudo /usr/local/nginx/sbin/nginx
HLS 直播流配置
找到http-->server,在花括號中增加
server {
listen 8080;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
#HLS配置開始,這個配置為了`客戶端`能夠以http協議獲取HLS的拉流
location /hls {
# Serve HLS fragments
types {
application/vnd.apple.mpegurl m3u8;
video/mp2t ts;
}
root html;
add_header Cache-Control no-cache;
}
#HLS配置結束
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
找到rtmp下的server在花括號中增加
#在http節點下面(也就是文件的尾部)加上rtmp配置:
rtmp {
server {
listen 1935;
application zbcs {
live on;
record off;
}
#增加對HLS支持開始
application hls {
live on;
hls on;
hls_path /usr/local/var/www/hls;
hls_fragment 5s;
}
#增加對HLS支持結束
}
}
說明:
- live on; 開啟實時
- hls on; 開啟hls
- hls_path; ts文件存放路徑
- hls_fragment 5s; 每個TS文件包含5秒的視頻內容
HLS直播延時
我們知道hls協議是將直播流分成一段一段的小段視頻去下載播放的,所以假設列表里面的包含5個ts文件,每個TS文件包含5秒的視頻內容,那么整體的延遲就是25秒。因為當你看到這些視頻時,主播已經將視頻錄制好上傳上去了,所以時這樣產生的延遲。當然可以縮短列表的長度和單個ts文件的大小來降低延遲,極致來說可以縮減列表長度為1,並且ts的時長為1s,但是這樣會造成請求次數增加,增大服務器壓力,當網速慢時回造成更多的緩沖,所以蘋果官方推薦的ts時長時10s,所以這樣就會大改有30s的延遲。參考資料:
保存配置文件,重新加載nginx配置
nginx -s reload
進行推流
ffmpeg推流還是和上一篇的一樣,不過,我們需要推到新配置的hls中,movie 關鍵字可以任何替換
ffmpeg -re -i /Users/jiangys/Documents/Document/demo.mp4 -vcodec copy -f flv rtmp://localhost:1935/hls/movie
然后,我們在就可以在這個目錄下(這個也是Nginx下html默認配置文件)
/usr/local/var/www/hls
看到生成一個個ts的文件,還會生成一個”你的m3u8的文件名稱.m3u8“的文件

測試拉流
通過上面的配置,我們可以同時通過rtmp和hls兩種播放方式來看到推出來的流。注意,如果使用 http 方式,則是監聽的 8080 端口,這個是在配置文件里寫的
(1) 用rtmp:(使用VLC驗證播放)
rtmp://192.168.1.100/hls/movie
(2) 用hls播放
http://192.168.1.100:8080/hls/movie.m3u8
對於hls拉流,除了使用VLC播放之后,我們還可以在Safari瀏覽器里輸入上面的地址直接播放,也可以用iPad或者iPhone上的Safari來訪問(需要把localhost改為nginx的所在電腦的ip地址)

補充
1 、HLS中,我們想把推流生成的ts文件存放在指定的目錄下,比如"/tmp/hls"
application hls {
live on;
hls on;
hls_path /tmp/hls;
}
那么,我們也需要在http-->server中對root 路徑更改為:/tmp 。要不然,會拉不到流。

root html 是指使用當前nginx服務器根目錄所在位置,指向的是 /usr/local/var/www 這個目錄

