Nginx

ngx_http_mp4_module

ngx_http_mp4_module模块

  • 示例配置

  • 指令

  • mp4

  • mp4_buffer_size

  • mp4_max_buffer_size

  • mp4_limit_rate

  • mp4_limit_rate_after

ngx_http_mp4_module模块为MP4文件提供伪流式服务器端支持。这些文件通常具有.mp4.m4v.m4a文件扩展名。

伪流与兼容的Flash播放器结盟。播放器以查询字符串参数中指定的开始时间(简单命名为start并以秒为单位指定)向服务器发送HTTP请求,并且服务器响应该流,使其起始位置与请求的时间相对应,例如:

http://example.com/elephants_dream.mp4?start=238.88

这允许随时执行随机查找,或者在时间线中间开始回放。

为了支持搜索,基于H.264的格式将元数据存储在所谓的“moov原子”中。它是保存整个文件的索引信息的文件的一部分。

要开始播放,播放器首先需要读取元数据。这是通过发送带有start=0参数的特殊请求来完成的。许多编码软件在文件的末尾插入元数据。这对于伪流播来说是不理想的,因为播放器必须在开始播放之前下载整个文件。如果元数据位于文件的开头,那么nginx就可以简单地开始发回文件内容。如果元数据位于文件末尾,nginx必须读取整个文件并准备一个新流,以便元数据位于媒体数据之前。这涉及到一些CPU,内存和磁盘I / O开销,所以最好事先准备一个用于虚拟流式传输的原始文件,而不是让nginx在每一个这样的请求上都这样做。

该模块还支持end设置播放结束点的HTTP请求参数(1.5.13)。该end参数可以与所述被指定的start参数或单独:

http://example.com/elephants_dream.mp4?start=238.88&end=555.55

对于具有非零startend参数的匹配请求,nginx将从文件中读取元数据,准备具有所需时间范围的流并将其发送到客户端。这与上面描述的开销相同。

如果匹配的请求不包含startend参数,则不会有开销,并且文件仅作为静态资源发送。有些玩家也支持字节范围请求,因此不需要这个模块。

该模块不是默认生成的,它应该使用--with-http_mp4_module配置参数启用。

如果以前使用过第三方mp4模块,应该禁用它。

ngx_http_flv_module模块提供了对FLV文件的类似伪流式支持。

示例配置

location /video/ { mp4; mp4_buffer_size 1m; mp4_max_buffer_size 5m; mp4_limit_rate on; mp4_limit_rate_after 30s; }

指令

句法:MP4;
默认:
语境:位置

打开周围位置的模块处理。

句法:mp4_buffer_size大小;
默认:mp4_buffer_size 512K;
语境:http,服务器,位置

设置size用于处理MP4文件的缓冲区的初始值。

句法:mp4_max_buffer_size大小;
默认:mp4_max_buffer_size 10M;
语境:http,服务器,位置

在元数据处理期间,可能需要更大的缓冲区。其大小不能超过指定的大小size,否则nginx将返回500(内部服务器错误)服务器错误,并记录以下消息:

"/some/movie/file.mp4" mp4 moov atom is too large: 12583268, you may want to increase mp4_max_buffer_size

句法:mp4_limit_rate 开启| 关闭| factor;
默认:mp4_limit_rate关闭;
语境:http,服务器,位置

限制对客户的响应传输速率。费率基于所提供MP4文件的平均比特率进行限制。要计算比率,比特率将乘以指定的比特率factor。特殊值“ on”对应于1.1的因子。特殊值“ off”禁用速率限制。限制是根据请求设置的,所以如果客户端同时打开两个连接,总体速率将是指定限制的两倍。

该指令可作为我们商业订阅的一部分。

句法:mp4_limit_rate_after时间;
默认:mp4_limit_rate_after 60s;
语境:http,服务器,位置

设置媒体数据的初始数量(在播放时间内测量),然后将响应进一步传输到客户端将受到速率限制。

该指令可作为我们商业订阅的一部分。