0

我目前使用如下命令接收并存储来自带有 openRTSP 的摄像机的 RTSP 流:

openRTSP -4 "rtsp://192.168.41.185/rtsp_tunnel?h26x=4&line=1&inst=2" > movie.mp4

我可以使用 FFmpeg 做同样的事情:

ffmpeg -i "rtsp://192.168.41.185/rtsp_tunnel?h26x=4&line=1&inst=2" -vcodec copy movie.mp4

来自相机的视频帧为 1280x720 (H.264),速度约为 30 fps,并带有毫秒时间戳。当我查看由 ffmpeg 创建的 movie.mp4 时,它看起来非常漂亮,视频流中的秒数似乎相当准确. 相反,如果我查看由 openRTSP 创建的movie.mp4,视频时间戳中的秒数肯定比现实中的秒长。因此,视频上的一秒钟实际上可以持续两秒钟。我做了几次测试,这不是网络性能或处理从相机接收到的消息的问题。原因似乎是消息被编码到这个 MP4 容器中的部分

FFmpeg 这样做比 openRTSP 快得多吗?

我可以以某种方式优化 openRTSP 中的 MP4 编码吗?

4

1 回答 1

0

好的,这不是性能问题,而是 openRTSP 无法从 RTSP 流中检测到正确帧速率的问题。我准确记录了 60 秒,并且按照建议,我曾经ffprobe获取有关比特流的更多信息:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'output-00000-00060.mp4':
  Metadata:
    major_brand     : mp42
    minor_version   : 0
    compatible_brands: mp42isom
    creation_time   : 2018-07-02 03:30:01
  Duration: 00:04:00.13, start: 0.000000, bitrate: 46 kb/s
    Stream #0:0(eng): Video: h264 (Main) (avc1 / 0x31637661), yuvj420p(pc, bt470bg/bt470bg/iec61966-2-1), 1280x720 [SAR 561:560 DAR 187:105], 45 kb/s, 15 fps, 15 tbr, 600 tbn, 1200 tbc (default)
    Metadata:
      creation_time   : 2018-07-02 03:30:01
      handler_name    : ?Apple Alias Data Handler
      encoder         : H.264

有两点不对:

  • 问题 #1:帧速率不是 15 fps,但相机配置为尝试发送 30 fps。
  • 问题 #2:持续时间是 4:00,但应该是 1:00

对于问题 #1:这可能是我的错。我应该手动指定帧速率,因为 openRTSP 没有从流中获取它。我应该指定选项-f 30

对于问题 #2:在给出选项后,-f 30我仍然得到一个持续时间为 2:00 而不是 1.00 的视频文件。我想问题在于相机以逐行模式而不是隔行模式发送数据。也许 openRTSP 的默认设置是隔行扫描模式。所以当我把帧率加倍时-f 60一切都好。

也许有人可以证实我的猜测?

于 2018-07-02T12:27:57.213 回答