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
为何选择Nginx做为支持HTTP-FLV方式直播的服务器呢?由于Nginx的Web服务器功能对HTTP协议的支持很是完善,Nginx的性能优秀,通过了不少场景的检验。另外,Nginx自己对第三方软件的依赖较少,很是易于部署。这些都使得它成为HTTP-FLV方式直播服务器不可多得的选择。git
listen
配置项而不影响基本功能支持HTTP-FLV方式的直播
支持的播放器有VLC,OBS和flv.js等,只须要输入以下地址便可:github
http://yourdomain[:httpport]/dir?[rtmpport=xxx&]app=yyy&stream=zzz
其中httpport是Nginx的配置文件中http
块中监听的端口,若是这个端口是80,那么能够省略不写;rtmpport是Nginx的配置文件中rtmp
块中监听的端口,若是这个端口是1935,那么能够省略不写。dir
是Nginx的配置文件中http
块中location
后的路径。参数app和stream见下文的推流一节说明。
nginx-http-flv-module也支持HTTPS-FLV方式的直播。缓存
支持GOP缓存,以减小首屏时间
只须要在rtmp
块中的application
块中添加以下配置项便可:服务器
gop_cache on;
如今的代码中只缓存两个GOP,若是须要修改GOP缓存个数,能够自行修改代码,可是不建议将GOP缓存的个数设置太大,由于发送GOP缓存可能须要不少次I/O操做,可能耗费比较多的时间,从而影响整个服务器的性能。网络
支持虚拟主机功能
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
来指定域名,也支持前向通配,后向通配和彻底匹配:app
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; #彻底匹配 }
注意:虚拟主机功能在多进程模式下还有问题。dom
listen
配置项而不影响基本功能rtmp
块中不指定listen
,而后推流和播放会不会出现问题。为了简便起见,假设不使用比较复杂的选项,这里以ffmpeg为例:ide
ffmpeg -re -i media_file -vcodec copy -acodec copy -f flv rtmp://yourdomain/app/stream
上文中HTTP-FLV的URL中的app和stream与这里的app和stream对应,它们都是RTMP协议中的概念。
也可使用OBS推流,这里再也不详述。性能
在个人笔记本上(ThinkPad T410,Intel Core i5 M480,4G内存,Debian 7.11)压力测试,单进程(多进程还有些问题没解决)200推流和1000播放没有问题。
答案是有的。我知道商用的有不下10家,规模比较大的一家是CDN厂商,另外一家是网络电视厂商。另外,据网友反馈,国外也有网站在用这个模块。还有华为也打算使用本模块,这是我已知的最大的一个对本模块感兴趣的厂商了。
欢迎你们试用nginx-http-flv-module,也欢迎反馈bug和提交pr。
最后贴两张调试nginx-http-flv-module时的测试截图:
RTMP和HTTP-FLV测试截图
flv.js测试截图