10

我正在使用以下命令为 html5 流式传输创建一个分段的 mp4:

-i rtsp://172.20.28.52:554/h264 -vcodec copy -an -f mp4 -reset_timestamps 1 -movflags empty_moov+default_base_moof+frag_keyframe -loglevel quiet -
  1. “-i rtsp://172.20.28.52:554/h264”,因为源是来自 ip 摄像机的 rtp 数据包流中的 h264。为了测试起见,相机设置GOP为1(即所有帧都是关键帧)
  2. “-vcodec 复制”因为我不需要转码,只需要重新混合到 mp4。
  3. "-movflags empty_moov+default_base_moof+frag_keyframe" 根据媒体源扩展规范创建分段 mp4。
  4. 最后的“-”以便将 mp4 输出到标准输出。我正在获取输出并通过网络套接字将其发送到网络客户端。

一切运行良好,期待我试图解决的延迟问题。如果我每次从标准输出输入数据时都在记录,并带有到达的时间戳,我会得到以下输出:

16/06/2015 15:40:45.239 得到数据大小 = 24

16/06/2015 15:40:45.240 得到数据大小 = 7197

16/06/2015 15:40:45.241 得到数据大小 = 32768

16/06/2015 15:40:45.241 得到数据大小 = 4941

16/06/2015 15:40:45.241 得到数据大小 = 12606

16/06/2015 15:40:45.241 得到数据大小 = 6345

16/06/2015 15:40:45.241 得到数据大小 = 6339

16/06/2015 15:40:45.242 得到数据大小 = 6336

16/06/2015 15:40:45.242 得到数据大小 = 6361

16/06/2015 15:40:45.242 得到数据大小 = 6337

16/06/2015 15:40:45.242 得到数据大小 = 6331

16/06/2015 15:40:45.242 得到数据大小 = 6359

16/06/2015 15:40:45.243 得到数据大小 = 6346

16/06/2015 15:40:45.243 得到数据大小 = 6336

16/06/2015 15:40:45.243 得到数据大小 = 6338

16/06/2015 15:40:45.243 得到数据大小 = 6357

16/06/2015 15:40:45.243 得到数据大小 = 6357

16/06/2015 15:40:45.243 得到数据大小 = 6322

16/06/2015 15:40:45.243 得到数据大小 = 6359

16/06/2015 15:40:45.244 得到数据大小 = 6349

16/06/2015 15:40:45.244 得到数据大小 = 6353

16/06/2015 15:40:45.244 得到数据大小 = 6382

16/06/2015 15:40:45.244 得到数据大小 = 6403

16/06/2015 15:40:45.304 得到数据大小 = 6393

16/06/2015 15:40:45.371 得到数据大小 = 6372

16/06/2015 15:40:45.437 得到数据大小 = 6345

16/06/2015 15:40:45.504 得到数据大小 = 6352

16/06/2015 15:40:45.571 得到数据大小 = 6340

16/06/2015 15:40:45.637 得到数据大小 = 6331

16/06/2015 15:40:45.704 得到数据大小 = 6326

16/06/2015 15:40:45.771 得到数据大小 = 6360

16/06/2015 15:40:45.838 得到数据大小 = 6294

16/06/2015 15:40:45.904 得到数据大小 = 6328

16/06/2015 15:40:45.971 得到数据大小 = 6326

16/06/2015 15:40:46.038 得到数据大小 = 6326

16/06/2015 15:40:46.105 得到数据大小 = 6340

16/06/2015 15:40:46.171 得到数据大小 = 6341

16/06/2015 15:40:46.238 得到数据大小 = 6332

如您所见,前 23 行(包含约 1.5 秒视频的数据)几乎立即到达,然后每 2 行连续行之间的延迟约为 70 毫秒,这是有道理的,因为视频是每秒 15 帧。此行为引入了大约 1.5 秒的延迟。

这看起来像是一个刷新问题,因为我看不出 ffmpeg 需要在内存中保存前 23 帧的任何理由,特别是因为每一帧都是它自己在 mp4 中的片段。但是,我找不到任何可以使 ffmpeg 更快地刷新这些数据的方法。

有人有建议吗?

我想指出,这是对此问题的后续问题: Live streaming dash content using mp4box

4

3 回答 3

5

消除延迟的关键是使用 -probesize 参数:

probesize 整数(输入)

以字节为单位设置探测大小,即分析获取流信息的数据大小。如果信息分散到流中,较高的值将能够检测到更多信息,但会增加延迟。必须是不小于 32 的整数。默认为 5000000。

默认情况下,该值为 5,000,000 字节,相当于约 1.5 秒的视频。通过将值减小到 200,000,我几乎可以完全消除延迟。

于 2015-09-30T07:49:04.660 回答
0

我通过使用 -g 选项设置组中的帧数解决了延迟问题。就我而言,我使用了-g 2. 我怀疑如果您不明确说明,片段要么等待源提供关键帧,要么使用非常大的默认值来生成关键帧,然后关闭片段并将其转储到标准输出。

于 2015-07-30T05:14:52.643 回答
0

在控制台输出的情况下,通常会禁用标准输出的缓冲。如果从代码运行 ffmpeg,则启用缓冲,因此只有在缓冲区已满或命令结束时才会获取数据。

您必须消除操作系统的标准输出缓冲。在 Windows 上它是不可能的 imo,但在 ubuntu 上是 ex。有http://manpages.ubuntu.com/manpages/maverick/man1/stdbuf.1.html

于 2015-08-26T06:33:42.983 回答