ffmpeg 在后台运行时挂起

Posted

技术标签:

【中文标题】ffmpeg 在后台运行时挂起【英文标题】:ffmpeg hangs when run in background 【发布时间】:2013-05-07 14:05:12 【问题描述】:

如果我按如下方式运行 ffmpeg:

ffmpeg -i H264-media-4.264 4.avi

它工作正常(即 4.avi 创建正常)。但是,如果我尝试在后台运行它:

ffmpeg -i H264-media-4.264 4.avi &

挂了! (和 4.avi 从未创建) 有什么想法吗?


注意:当尝试将它作为子进程运行时,问题是python中类似问题的隔离,并且它也挂起:ff.py包括

ps = subprocess.Popen(ffmpeg_list, stderr=subprocess.STDOUT,stdout = subprocess.PIPE)

运行./ff.py 运行正常,./ff.py & 也挂起。

系统:CentOS 6.6 ffmpeg: 0.10.2

成功运行的结果:

 ffmpeg version 0.10.2 Copyright (c) 2000-2012 the FFmpeg developers
 built on Mar 20 2012 04:34:50 with gcc 4.4.6 20110731 (Red Hat 4.4.6-3)
  configuration: --prefix=/usr --libdir=/usr/lib64 --shlibdir=/usr/lib64 --mandir=/usr/share/man --enable-shared --enable-runtime-cpudetect --enable-gpl --enable-version3 --enable-postproc --enable-avfilter --enable-pthreads --enable-x11grab --enable-vdpau --disable-avisynth --enable-frei0r --enable-libopencv --enable-libdc1394 --enable-libdirac --enable-libgsm --enable-libmp3lame --enable-libnut --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-librtmp --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libxavs --enable-libxvid --extra-cflags='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -fPIC' --disable-stripping
  libavutil      51. 35.100 / 51. 35.100
  libavcodec     53. 61.100 / 53. 61.100
  libavformat    53. 32.100 / 53. 32.100
  libavdevice    53.  4.100 / 53.  4.100
  libavfilter     2. 61.100 /  2. 61.100
  libswscale      2.  1.100 /  2.  1.100
  libswresample   0.  6.100 /  0.  6.100
  libpostproc    52.  0.100 / 52.  0.100
[h264 @ 0x24eac00] max_analyze_duration 5000000 reached at 5000000
[h264 @ 0x24eac00] Estimating duration from bitrate, this may be inaccurate
Input #0, h264, from 'H264-media-4.264':
  Duration: N/A, bitrate: N/A
    Stream #0:0: Video: h264 (Baseline), yuv420p, 640x480 [SAR 1:1 DAR 4:3], 25 fps, 25 tbr, 1200k tbn, 50 tbc
[buffer @ 0x24efa60] w:640 h:480 pixfmt:yuv420p tb:1/1000000 sar:1/1 sws_param:
[mpeg4 @ 0x24eb540] removing common factors from framerate
Output #0, avi, to '4.avi':
  Metadata:
    ISFT            : Lavf53.32.100
    Stream #0:0: Video: mpeg4 (FMP4 / 0x34504D46), yuv420p, 640x480 [SAR 1:1 DAR 4:3], q=2-31, 200 kb/s, 25 tbn, 25 tbc
Stream mapping:
  Stream #0:0 -> #0:0 (h264 -> mpeg4)
Press [q] to stop, [?] for help
frame= 2324 fps=477 q=31.0 Lsize=    2603kB time=00:01:32.96 bitrate= 229.4kbits/s    
video:2542kB audio:0kB global headers:0kB muxing overhead 2.409572%

挂起跑的结果:

ffmpeg version 0.10.2 Copyright (c) 2000-2012 the FFmpeg developers
  built on Mar 20 2012 04:34:50 with gcc 4.4.6 20110731 (Red Hat 4.4.6-3)
  configuration: --prefix=/usr --libdir=/usr/lib64 --shlibdir=/usr/lib64 --mandir=/usr/share/man --enable-shared --enable-runtime-cpudetect --enable-gpl --enable-version3 --enable-postproc --enable-avfilter --enable-pthreads --enable-x11grab --enable-vdpau --disable-avisynth --enable-frei0r --enable-libopencv --enable-libdc1394 --enable-libdirac --enable-libgsm --enable-libmp3lame --enable-libnut --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-librtmp --enable-libschroedinger --enable-libspeex --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libxavs --enable-libxvid --extra-cflags='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -fPIC' --disable-stripping
  libavutil      51. 35.100 / 51. 35.100
  libavcodec     53. 61.100 / 53. 61.100
  libavformat    53. 32.100 / 53. 32.100
  libavdevice    53.  4.100 / 53.  4.100
  libavfilter     2. 61.100 /  2. 61.100
  libswscale      2.  1.100 /  2.  1.100
  libswresample   0.  6.100 /  0.  6.100
  libpostproc    52.  0.100 / 52.  0.100


[5]+  Stopped                 ffmpeg -i H264-media-4.264 4.avi

【问题讨论】:

问题解决:需要添加"/null" ffmpeg -y -i input.avi output.avi /null >/dev/null 2>/var/log/ffmpeg .log & [slhck - 抱歉,我是新来的……] 您应该尽可能在下面发布您的答案作为答案。您应该能够在大约 8 小时内完成此操作。我编辑了您的问题以更正格式 - 请尝试在将来坚持代码格式。 【参考方案1】:

它挂起是因为在某个点之后它不能再写入它的输出管道。

当您运行一个进程时,它有 3 个打开的管道用于:stdin、stdout 和 stderr。管道有一个内存缓冲区(Linux 上为 4KB),可以容纳一定数量的数据,并且下一次写入操作将暂停,直到从管道的另一端读取一些数据。

由于您从未从子进程的 stdout 和 stderr 中读取数据,并且 FFMpeg 输出很多,因此它会在某个时候挂起。

正如上面评论中所解释的,你可以简单地将你的 ffmpeg 输出重定向到 /dev/null 使用:

ffmpeg .... > /dev/null 2>&1 < /dev/null

在这种情况下,ffmpeg 永远不会输出足够的数据来让管道“挂起”。

另一种选择是在启动子进程后立即关闭子进程的标准输入、标准输出和标准错误。

另一种选择是实际读取(并可选择丢弃)子进程的 stdout 和 stderr 上的所有内容。

【讨论】:

哇....太棒了...我同时使用 Windows 和 Linux(为了便于兼容),并且在 Windows 中,此方法有效,必须将 /dev/null 更改为 NUL,即是:ffmpeg .... > NUL 2>&1 ***.com/questions/313111/dev-null-in-windows 我在 Windows 10 上遇到了这个问题。如何清除它?每当我尝试使用任何参数运行 ffmpeg 时,它都会挂起。我可以从其他用户的控制台运行它,但不是我自己的。如何疏通这个? %appdata% 中是否有文件? 大多数时候我的经验是ffmpeg -nostats -loglevel fatal ... 的输出足够小,可以放入进程运行时不读取的缓冲区。而且......在发生致命错误的情况下,您还没有丢弃整个输出。【参考方案2】:

ffmpegenables interaction with stdin by default。在 Mac OS X 和 Linux 系统上,这会导致在后台运行的 ffmpeg 作业暂停。在调用中添加选项 -nostdin 会导致 ffmpeg 不启用 stdin 交互,从而避免暂停后台进程。

在您的示例中,尝试:

ffmpeg -nostdin -i H264-media-4.264 4.avi &

注意:ffmpeg documentation, 5.4 Main options 表示其他答案中提到的输入重定向:

ffmpeg ... &lt; /dev/null

与使用-nostdin 实现“大致相同的结果”,但需要一个shell。

您什么时候想在没有 shell 的情况下运行 ffmpeg?当将其作为子进程调用时,例如使用 Python 的 subprocess.run()

【讨论】:

我在从Go 拨打ffmpeg 时遇到了类似的问题,这让我头疼了好几个星期。您对-nostdin 的建议似乎已经解决了。 ? 我需要这个标志,以及来自@ErJab 的 -loglevel 错误,但它有效!谢谢,这让我发疯了!【参考方案3】:

正如其他人所指出的,该问题是由 ffmpeg 使标准输出和/或标准错误饱和并带有详细消息引起的。所以另一种选择可能是关闭 ffmpeg 的日志级别:

ffmpeg -loglevel error -i H264-media-4.264 4.avi &

有关 ffmpeg 中日志级别的更多信息,请参阅 this question。

【讨论】:

以上是关于ffmpeg 在后台运行时挂起的主要内容,如果未能解决你的问题,请参考以下文章

使用 cl 编译的代码在第一次运行时挂起太久[关闭]

npm 在安装后/解锁时挂起

我可以在 userControl 中使用线程来防止应用程序运行时挂起吗?

长时间运行的后台任务完成后应用程序未挂起

独立的 Windows 应用程序在焦点更改时挂起

linux 远程主机后台运行任务 挂起脚本