支持HTTP-FLV方式直播的开源模块nginx-http-flv-module

卷确 2019-06-28

nginx-http-flv-module是在nginx-rtmp-module基础上开发的一个直播模块。
感谢Arut创造了nginx-rtmp-module,它是Nginx的一个优秀的第三方模块,可以用来直播,支持RTMP,HLS和DASH方式直播,还支持调用第三方软件进行转码,录制视频等功能,由于依托Nginx,性能也比较高。但是美中不足的地方也不少,例如首屏时间长,不支持HTTP-FLV方式直播,不支持虚拟主机(vhost)功能,省略listen配置无法接受连接,有很多很明显的bug等问题。
nginx-http-flv-module解决了上述的问题。当然,还有些bug还有待修复。具体使用方法请参考说明文件:

为什么选择Nginx作为支持HTTP-FLV方式直播的服务器呢?因为Nginx的Web服务器功能对HTTP协议的支持非常完善,Nginx的性能优秀,经过了很多场景的检验。另外,Nginx本身对第三方软件的依赖较少,非常易于部署。这些都使得它成为HTTP-FLV方式直播服务器不可多得的选择。

nginx-http-flv-module的功能

  1. 兼容nginx-rtmp-module所有功能
  2. 支持HTTP-FLV方式的直播
  3. 支持GOP缓存,以减少首屏时间
  4. 支持虚拟主机功能
  5. 可以省略listen配置项而不影响基本功能
  6. 修复nginx-rtmp-module已知的bug

功能简介

  1. 兼容nginx-rtmp-module的所有功能,详细说明参考nginx-rtmp-moduleWiki
  2. 支持HTTP-FLV方式的直播
    支持的播放器有VLCOBSflv.js等,只需要输入如下地址即可:

    http://yourdomain[:httpport]/dir?[rtmpport=xxx&]app=yyy&stream=zzz

    其中httpport是Nginx的配置文件中http块中监听的端口,如果这个端口是80,那么可以省略不写;rtmpport是Nginx的配置文件中rtmp块中监听的端口,如果这个端口是1935,那么可以省略不写。dir是Nginx的配置文件中http块中location后的路径。参数app和stream见下文的推流一节说明。
    注意
    使用flv.js时,flv.js有解析错误,可以在rtmp块中添加下面的配置项来避免:

    meta off;

    nginx-http-flv-module也支持HTTPS-FLV方式的直播。

  3. 支持GOP缓存,以减少首屏时间
    只需要在rtmp块中的application块中添加如下配置项即可:

    gop_cache on;

    现在的代码中只缓存两个GOP,如果需要修改GOP缓存个数,可以自行修改代码,但是不建议将GOP缓存的个数设置太大,因为发送GOP缓存可能需要很多次I/O操作,可能耗费比较多的时间,从而影响整个服务器的性能。

  4. 支持虚拟主机功能
    nginx-rtmp-module不支持虚拟主机功能。那什么是虚拟主机功能呢?假设有一台服务器,其IP地址是192.168.1.110,我配置了一个DNS服务器,将两个域名www.testa.com和www.testb.com都指向192.168.1.110,那么对于Web服务,我可以针对这两个域名配置不同的Web页面,通过不同的域名访问不同的Web页面,但其实这两个不同的服务都指向同一台服务器。这两个域名对应同一个IP地址就是虚拟主机功能。与http配置一样,nginx-http-flv-module通过server_name来指定域名,也支持前向通配,后向通配和完全匹配:

    server {
        server_name *.test.com; #前向通配,匹配blog.test.com/login.test.com等
        ...
    }
    
    server {
        server_name www.test.*; #后向通配,匹配www.test.org/www.test.com等
        ...
    }
    
    server {
        server_name www.test.com; #完全匹配
    }

    注意:虚拟主机功能在多进程模式下还有问题。

  5. 可以省略listen配置项而不影响基本功能
    这个略,大家可以试试使用nginx-rtmp-module时,在rtmp块中不指定listen,然后推流和播放会不会出现问题。
  6. 修复nginx-rtmp-module已知的bug
    大多是一些比较明显的错误,如指令对应的宏写错了,消息个数计算错误等。

推流

为了简便起见,假设不使用比较复杂的选项,这里以ffmpeg为例:

ffmpeg -re -i media_file -vcodec copy -acodec copy -f flv rtmp://yourdomain/app/stream

上文中HTTP-FLV的URL中的app和stream与这里的app和stream对应,它们都是RTMP协议中的概念。
也可以使用OBS推流,这里不再详述。

nginx-http-flv-module性能如何?

在我的笔记本上(ThinkPad T410,Intel Core i5 M480,4G内存,Debian 7.11)压力测试,单进程(多进程还有些问题没解决)200推流和1000播放没有问题。

有人用nginx-http-flv-module吗?

答案是有的。我知道商用的有不下10家,规模比较大的一家是CDN厂商,另一家是网络电视厂商。另外,据网友反馈,国外也有网站在用这个模块。还有华为也打算使用本模块,这是我已知的最大的一个对本模块感兴趣的厂商了。
欢迎大家试用nginx-http-flv-module,也欢迎反馈bug和提交pr。
最后贴两张调试nginx-http-flv-module时的测试截图:

RTMP和HTTP-FLV测试截图
支持HTTP-FLV方式直播的开源模块nginx-http-flv-module

flv.js测试截图
支持HTTP-FLV方式直播的开源模块nginx-http-flv-module

相关推荐

lwplvx / 0评论 2020-11-22
岁月如歌 / 0评论 2020-07-21