前提・実現したいこと
SkyWay WebRTCゲートウェイとffmpegを利用してWebRTCの録画を試しています。
これらを用いて、WebRTCによる会話を録画したいと考えています。
発生している問題・エラーメッセージ
videoの録画をすると、通話開始からだいたい1分くらいの間の映像が録画できない状態になってしまっています。
(3分の会話なら、前半の1分程度が切れて2分程度の動画ファイルになる)
audioの録音だけなら、videoのように前半が切れたりはしないです。
ffmpegのログの一部を以下に示します。
[sdp @ 0x7318f40] Keyframe missing [vp8 @ 0x732a600] Format yuv420p chosen by get_format(). [sdp @ 0x7318f40] All info found [sdp @ 0x7318f40] After avformat_find_stream_info() pos: 162 bytes read:162 seeks:0 frames:21 Input #0, sdp, from 'input-video.sdp': Metadata: title : No Name Duration: N/A, start: 64.879000, bitrate: N/A Stream #0:0, 21, 1/90000: Video: vp8, 1 reference frame, yuv420p(tv, bt470bg/unknown/unknown), 640x480, 0/1, 90k tbr, 90k tbn, 90k tbc Successfully opened the file.
入力用のSDPファイルを読み込んだ辺りのログだと思うのですが、"Keyframe missing"が表示されてから"Format yuv420p chosen by get_format()."が表示されるまで1分くらい間が空いています。
また、"Duration: N/A, start: 64.879000, bitrate: N/A"の部分のstartの値が、開始からの録画できていない秒数と一致しているようです。
この時間が短縮されるような設定が必要なのだと思うのですが、アドバイスなどご教授よろしくお願いいたします。
該当のソースコード
bash
1ffmpeg -start_at_zero -copyts \ 2 -analyzeduration 60M -probesize 60M \ 3 -protocol_whitelist file,crypto,udp,rtp \ 4 -i input-video.sdp \ 5 -vcodec copy \ 6 -force_key_frames "expr:gte(t,n_forced*4)" \ 7 -keyint_min 4 -g 4 \ 8 -rtbufsize 20MB \ 9 -loglevel debug \ 10 -reorder_queue_size 4000 \ 11 -max_delay 10000000 \ 12 -cluster_size_limit 10M \ 13 -cluster_time_limit 2100 \ 14 -y \ 15 output_video.webm 16
試したこと
skywayゲートウェイにWebRTCの映像と音声を出力している状態から、上記コマンドを実行して録画を試しました。
補足情報(FW/ツールのバージョンなど)
AWS EC2 で試しました。
あなたの回答
tips
プレビュー