使用网络摄像头通过 ffmpeg 进行极低延迟的流式传输

use*_*trm 6 ffmpeg video-encoding video-streaming live-streaming libx264

我正在尝试配置 ffmpeg 以使用网络摄像头进行实时视频流。我使用的ffmpeg编码器命令如下。

ffmpeg -f v4l2 -input_format yuyv422 -s 640x480 -i /dev/video0 -c:v libx264 -profile:v baseline -trellis 0 -subq 1 -level 32 -preset superfast -tune zerolatency -me_method epzs -crf 30 -threads 0 -bufsize 1 -refs 4 -coder 0 -b_strategy 0 -bf 0 -sc_threshold 0 -x264-params vbv-maxrate=2000:slice-max-size=1500:keyint=30:min-keyint=10: -pix_fmt yuv420p -an -f mpegts udp://192.168.1.8:5001
Run Code Online (Sandbox Code Playgroud)

用于显示视频源的 ffplay 命令是,

ffplay -analyzeduration 1 -fflags -nobuffer -i udp://192.168.1.8:5001
Run Code Online (Sandbox Code Playgroud)

但是,我在视频流中遇到了 0.5 - 1.0 秒的延迟。有没有办法将其减少到小于 100 毫秒。此外,当我用 x11grab 的屏幕捕获替换 v4l2 相机捕获时,流几乎是实时的,我没有遇到明显的延迟。此外,将编码器从 x264 更改为 mpeg2 对延迟没有影响。此外,来自 ffmpeg 的统计数据显示编码器以 30fps 的速率执行,我相信这表明编码是实时的。这使得我所经历的延误只有一个原因。

  • 在网络摄像头中进行视频捕获期间使用 v4l2 时,缓冲区是否存在明显延迟?
  • 我认为在这种情况下传输延迟不会生效,因为在相同条件下使用屏幕捕获时我没有看到任何延迟。
  • 这个延迟可以进一步减少吗?有人可以想到使用不同的编码器配置来代替我一直使用的编码器配置吗?

小智 0

我使用了相同的发送指令,我用 ffplay 尝试了这个,它对我有用:

ffplay -analyzeduration 1 -fflags -nobuffer -probesize 32 -sync ext -i rtmp://localhost/live/STREAM_NAME
Run Code Online (Sandbox Code Playgroud)