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 插件搭建视频直播和点播服务器

相关文章
相关标签/搜索