Mac直播服務器Nginx配置對HLS的支持

在上一篇中Mac上搭建直播服務器Nginx+rtmp,咱們已經搭建了nginx+rtmp直播服務器。下面須要對Nginx服務器增長對HLS的支持。在Nginx增長對HLS種支持比較簡單,只是簡單的修改下配置文件nginx.conf便可。html

安裝 nginx 和 rtmp 模塊

有關 nginx 的編譯和安裝比較簡單,請參考上一篇中Mac上搭建直播服務器Nginx+rtmp。這裏提示如下幾點:ios

(1) 安裝好 nginx 後,打開配置文件: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支持結束
    }
}

說明:服務器

  1. live on; 開啓實時
  2. hls on; 開啓hls
  3. hls_path; ts文件存放路徑
  4. hls_fragment 5s; 每一個TS文件包含5秒的視頻內容

HLS直播延時app

咱們知道hls協議是將直播流分紅一段一段的小段視頻去下載播放的,因此假設列表裏面的包含5個ts文件,每一個TS文件包含5秒的視頻內容,那麼總體的延遲就是25秒。由於當你看到這些視頻時,主播已經將視頻錄製好上傳上去了,因此時這樣產生的延遲。固然能夠縮短列表的長度和單個ts文件的大小來下降延遲,極致來講能夠縮減列表長度爲1,而且ts的時長爲1s,可是這樣會形成請求次數增長,增大服務器壓力,當網速慢時回形成更多的緩衝,因此蘋果官方推薦的ts時長時10s,因此這樣就會大改有30s的延遲。參考資料:ide

https://developer.apple.com/library/ios/documentation/NetworkingInternet/Conceptual/StreamingMediaGuide/FrequentlyAskedQuestions/FrequentlyAskedQuestions.htmlpost

保存配置文件,從新加載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默認配置文件)ui

/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 這個目錄

 

 

參考文章:

使用 nginx 和 rtmp 插件搭建視頻直播和點播服務器

相關文章
相關標籤/搜索