【发布时间】:2020-03-02 11:33:26
【问题描述】:
我正在尝试在我大学的计算集群上运行 VideoPose3D 模型,但我遇到了一个问题,即 infer_video.py 脚本(在 Detectron 中运行)由于 ffprobe 而中断。有问题的命令是:
ffprobe -v error -select_streams v:0 -show_entries stream=width,height -of csv=p=0 filename_here
它应该返回输入视频的宽度、高度的元组。该脚本过去运行良好,但在我现在使用的视频中,出现了段错误。对于上下文,这是在计算集群 (Ubuntu) 上运行它的输出:
$ ffprobe data/test/00001/00001.mp4
ffprobe version 4.0.3 Copyright (c) 2007-2018 the FFmpeg developers
built with gcc 8.1.0 (GCC)
configuration: --prefix=/share/pkg.7/ffmpeg/4.0.3/install --enable-gpl --enable-libx264 --enable-hardcoded-tables --enable-pic --enable-shared --enable-lto
libavutil 56. 14.100 / 56. 14.100
libavcodec 58. 18.100 / 58. 18.100
libavformat 58. 12.100 / 58. 12.100
libavdevice 58. 3.100 / 58. 3.100
libavfilter 7. 16.100 / 7. 16.100
libswscale 5. 1.100 / 5. 1.100
libswresample 3. 1.100 / 3. 1.100
libpostproc 55. 1.100 / 55. 1.100
Segmentation fault
这是我的本地机器(Windows 10)上相同命令的输出:
$ ffprobe data\test\00001\00001.mp4
ffprobe version 4.2.1 Copyright (c) 2007-2019 the FFmpeg developers
built with gcc 9.1.1 (GCC) 20190807
configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
libavutil 56. 31.100 / 56. 31.100
libavcodec 58. 54.100 / 58. 54.100
libavformat 58. 29.100 / 58. 29.100
libavdevice 58. 8.100 / 58. 8.100
libavfilter 7. 57.100 / 7. 57.100
libswscale 5. 5.100 / 5. 5.100
libswresample 3. 5.100 / 3. 5.100
libpostproc 55. 5.100 / 55. 5.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'data\test\00001\00001.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf58.29.100
Duration: 00:02:52.18, start: 0.000000, bitrate: 1643 kb/s
Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709), 1920x1080 [SAR 1:1 DAR 16:9], 1512 kb/s, 24 fps, 24 tbr, 90k tbn, 48 tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 125 kb/s (default)
Metadata:
handler_name : SoundHandler
这让我相信它与 ffprobe 的版本有关,但我无法控制计算集群上安装的版本。它也没有解释为什么它以前曾在一个视频上工作过。有没有人有任何见识?我还有在计算集群上运行 ffprobe 的完整调试输出 gist, here.
编辑: 可能有用的进一步上下文,并让我相信这是一个版本问题,填充我的数据目录的视频是使用 youtube-dl 获取的。当我尝试在计算集群上使用 youtube-dl 时,它会失败,因为 ffmpeg 在尝试混合音频和视频流时会引发错误。当我在本地运行脚本(使用较新版本的 ffmpeg)时,不会发生此类错误。
ffmpeg 有一次在计算集群上工作,有问题的视频没有音频流,只有视频。这是旧版本 ffmpeg 的已知问题吗?我应该通过使用具有更高版本 ffmpeg 的 docker 容器来解决这个问题,还是人们建议的其他解决方法?
【问题讨论】:
-
4.0.3 有点老了...如果您想深入挖掘,gdb 可能会告诉您它在哪里爆炸...