Использование памяти FFmpeg - PullRequest
       24

Использование памяти FFmpeg

0 голосов
/ 16 октября 2018

Я использую новейшую библиотеку FFmpeg, чтобы объединить 4 разных входных видео.Для этого я делаю некоторые базовые операции «filter_complex» для видео и «amix» для аудио.Примерно через 1 минуту обработки данных процесс прерывается сигналом «SIGKILL».Вероятно, нехватка памяти вызывает эту ошибку.Чтобы проверить текущее использование памяти, я запускаю «верхний» инструмент, который в момент сбоя показывает, что 90% всей доступной памяти выделено.

В моем пуле kubernetes есть 30 ГБ ОЗУ и 8CPU.Это выглядит странно, потому что процесс FullHd потребляет 30 ГБ памяти за 1 минуту работы.

Интересно, есть ли способ оптимизировать или ограничить использование памяти.

Версия FFmpeg: 4.0.2 Система: Linuxкодировщик: h.264 формат: 1920x1080

FFmpeg вывод https://gist.github.com/mbutan/51f832a99d0edf0b09af934d1934971e

Фрагмент кода:

          ffmpeg \
  -i /tmp/a3ddcc11-9819-4bef-8e8d-156342aa68df.mp4 \
  -itsoffset 3 -i /tmp/c87d7e8f-c9e7-4fbe-b845-e6cd6d6ac7bb.mp4 \
  -itsoffset 3.199 -i /tmp/250cb6e8-8daf-4c5b-88b3-4b6cfb02834b.mp4 \
  -itsoffset 37.52 -i /tmp/24e466e1-c1e0-4797-b88a-09e2a9f5f673.mp4 \
  -itsoffset 68.04 -i /tmp/3e0e0e62-82e4-4d6a-881a-119d7c72cf9f.mp4 \
  -itsoffset 415.188 -i /tmp/02ca91d5-f0c1-4140-ba12-fa445f09ddf6.mp4 \
  -i /tmp/1.png -i /tmp/2.png -i /tmp/3.png \
  -y -filter_complex pad=1920:1080:color=black [base];[6] scale=1920:1080 [background];\
  [0:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_0];[base][main_0] overlay=90:50:enable=between'(t,0,3)' [tmp_4];\
  [1:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_1];[tmp_4][main_1] overlay=90:50:enable=between'(t,3,29.5)' [tmp_6];\
  [2:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_2];[tmp_6][main_2] overlay=90:50:enable=between'(t,29.5,37.5)' [tmp_8];\
  [3:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_3];[tmp_8][main_3] overlay=90:50:enable=between'(t,37.5,58)' [tmp_10];\
  [2:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_4];[tmp_10][main_4] overlay=90:50:enable=between'(t,58,68)' [tmp_12];\
  [4:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_5];[tmp_12][main_5] overlay=90:50:enable=between'(t,68,414.5)' [tmp_14];\
  [2:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_6];[tmp_14][main_6] overlay=90:50:enable=between'(t,414.5,415.5)' [tmp_16];\
  [5:v] scale=1740:980,pad=1740:980:(ow-iw)/2:(oh-ih)/2 [main_7];[tmp_16][main_7] overlay=90:50:enable=between'(t,415.5,416.248)' [tmp_18];\
  [tmp_18][background] overlay=0:0 [tmp_19];[7] scale=306.66666666666663:190[user_shadow_0];\
  [tmp_19][user_shadow_0] overlay=807:842:enable=between'(t,3.199,30.833)' [shadow_output_0_0];\
  [2:v] scale=266.66666666666663:150:force_original_aspect_ratio=decrease, pad=266.66666666666663:150:(ow-iw)/2:(oh-ih)/2:black [user_0_3199];\
  [shadow_output_0_0][user_0_3199] overlay=827:862:enable=between'(t,3.199,30.833)' [tmp_23];[7] scale=306.66666666666663:190[user_shadow_0];\
  [tmp_23][user_shadow_0] overlay=807:842:enable=between'(t,37.52,57.965)' [shadow_output_0_0];\
  [2:v] scale=266.66666666666663:150:force_original_aspect_ratio=decrease, pad=266.66666666666663:150:(ow-iw)/2:(oh-ih)/2:black [user_0_37520];\
  [shadow_output_0_0][user_0_37520] overlay=827:862:enable=between'(t,37.52,57.965)' [tmp_27];[7] scale=306.66666666666663:190[user_shadow_0];\
  [tmp_27][user_shadow_0] overlay=807:842:enable=between'(t,68.04,414.648)' [shadow_output_0_0];\
  [2:v] scale=266.66666666666663:150:force_original_aspect_ratio=decrease, pad=266.66666666666663:150:(ow-iw)/2:(oh-ih)/2:black [user_0_68040];\
  [shadow_output_0_0][user_0_68040] overlay=827:862:enable=between'(t,68.04,414.648)' [tmp_31];\
  [0:v] scale=1920:1080 [intro];[tmp_31][intro] overlay=0:0:enable=between'(t,0,3.25)' [tmp_32];\
  [tmp_32][0:v] overlay='if(lte((t-3.25)*18432,w),(t-3.25)*18432,w)':0:enable=between'(t,3.25,4.45)' [tmp_33];[5:v] scale=1920:1080 [end];\
  [tmp_33][end] overlay=0:0:enable=between'(t,414.75,418)' [tmp_34];\
  [tmp_34][5:v] overlay='if(lte((t-418)*18432,w),(t-418)*18432,w)':0:enable=between'(t,418,419.2)' [outVideo];\
  [0:a]adelay=1|1 [audio_0];\
  [1:a]adelay=3001|3001 [audio_1];\
  [2:a]adelay=3200|3200 [audio_2];\
  [3:a]adelay=37521|37521 [audio_3];\
  [4:a]adelay=68041|68041 [audio_4];\
  [5:a]adelay=415189|415189 [audio_5];\
  [audio_0][audio_1][audio_2][audio_3][audio_4][audio_5] amix=inputs=6:duration=longest \
  [outAudio] -map [outVideo] -map [outAudio] -framerate 30 -g 60 -video_size 1920x1080 -vcodec libx264 -acodec libfdk_aac -profile:a aac_he -b:a 192k -ac 2 -ar 44100 -max_muxing_queue_size 9999 -threads 0 -strict experimental -preset fast /tmp/53a89b44-fd56-4c5b-adb9-a5695d52e5d2_output.mp4

1 Ответ

0 голосов
/ 30 октября 2018

Проблема утечки памяти была решена с помощью последней ветки Мастер, большое спасибо Полу Б. Махолу за его преданность делу.Этот коммит исправляет упомянутую проблему: коммит

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...