FFMPEG“過去的持續時間 0.xxxxxx 太大”

FFMPEG“過去的持續時間 0.xxxxxx 太大”

我正在錄製 HLS 串流媒體,並且想保存在 FLV 容器中。

我的 ffmpeg 的指令是:

/.../recorder/class/ffmpeg-2.6.1-32bit-static/./ffmpeg  -i http://server/url/playlist.m3u8 -b:a 128K -acodec libmp3lame -ar 44100 -write_xing 0 -y -b:v 512K -vcodec flv -t 1860 /tmp/test.flv

它開始記錄,但在控制台輸出中我顯示了很多:Past duration 0.XXXXXX too large

這個警告是什麼意思?我該如何修復它們?

這是輸入資訊的控制台輸出:

ffmpeg version 2.6.1-   http://johnvansickle.com/ffmpeg/    Copyright (c) 2000-2015 the FFmpeg developers
  built with gcc 4.9.2 (Debian 4.9.2-10)
  configuration: --enable-gpl --enable-version3 --disable-shared --disable-debug --enable-runtime-cpudetect --enable-libmp3lame --enable-libx264 --enable-libx265 --enable-libwebp --enable-libspeex --enable-libvorbis --enable-libvpx --enable-libfreetype --enable-fontconfig --enable-libxvid --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-gray --enable-libopenjpeg --enable-libopus --enable-libass --enable-gnutls --enable-libvidstab --cc=gcc-4.9
  libavutil      54. 20.100 / 54. 20.100
  libavcodec     56. 26.100 / 56. 26.100
  libavformat    56. 25.101 / 56. 25.101
  libavdevice    56.  4.100 / 56.  4.100
  libavfilter     5. 11.102 /  5. 11.102
  libswscale      3.  1.101 /  3.  1.101
  libswresample   1.  1.100 /  1.  1.100
  libpostproc    53.  3.100 / 53.  3.100
Input #0, hls,applehttp, from 'http://server/url/playlist.m3u8':
  Duration: N/A, start: 35483.191100, bitrate: N/A
  Program 0 
    Metadata:
      variant_bitrate : 303609
    Stream #0:0: Video: h264 (Main) ([27][0][0][0] / 0x001B), yuv420p, 320x180 [SAR 1:1 DAR 16:9], 30 fps, 30 tbr, 90k tbn, 60 tbc
    Metadata:
      variant_bitrate : 303609
    Stream #0:1: Audio: aac (LC) ([15][0][0][0] / 0x000F), 44100 Hz, mono, fltp, 67 kb/s
    Metadata:
      variant_bitrate : 303609

我該如何解決這個問題?

答案1

這個帖子似乎有答案:“2015年1月15日之後的FFMpeg版本經常顯示此警告。添加它是為了警告可能的速率控制失真,否則不會造成任何傷害。”

當「輸入流中的呈現時間 (pts) 與輸出流中的呈現時間相差超過設定為 0.6 的固定限制」時,它似乎會被觸發

答案2

這似乎是一個新的「功能」:ffmpeg 垃圾郵件「過去的持續時間 xy 太大」訊息

在 ffmpeg 版本 2.6.2 中,它們每幀資訊 (frame=...) 寫出一次,在 2.6.git 中,它們主要出現在記錄開始時,然後以不規則的間隔出現。

相關內容