Opened 3 months ago

Last modified 3 months ago

#11259 new defect

"anull" insensibly eating memory

Reported by: Alfredo Di Napoli Owned by:
Priority: normal Component: avfilter
Version: 7.1 Keywords: anull
Cc: MasterQuestionable Blocked By:
Blocking: Reproduced by developer: no
Analyzed by developer: no

Description

At work we recently upgraded from 5.0.1 to 7.1.0, and we couldn't figure out why some machines in our cluster were really struggling; these are big machines with 16 cores and something like 30GB of RAM. By a quick htop inspection it seemed like for a single ffmpeg command, all the RAM was being eventually consumed and the machines started to swap. Removing the anull filter to the command made the leak go away. We could still see the memory climbing ever so slightly, but not in the same aggressive way.

To reproduce, consider the following command:

% /usr/local/bin/ffmpeg-7.1.0 -i /foo/left/master -i /foo/right/master -i /foo/left/master.muted.mov -i /foo/right/master.muted.mov -aspect 32:9 -y -filter_complex [1:1]anull[hms-1-1]  -filter_complex [0:1]anull[hms-0-1] -filter_complex '[2:v]setpts=PTS-STARTPTS,pad=iw*2:ih:color=white,framerate=30[l];[3:v]setpts=PTS-STARTPTS[r];[l][r]overlay=x=W-w:shortest=1[vout]' -map [vout] -map [hms-1-1] -map [hms-0-1] -shortest /foo/central/master.mp4

Without getting into too much detail, anull here is used just as a way to pass the audio stream, unchanged, to the final video. I can't remember why I'm using anull and not just mapping the relevant audio streams directly, but case on point, this command leaks quite severely. If we amend the command this way:

% /usr/local/bin/ffmpeg-7.1.0 -i /foo/left/master -i /foo/right/master -i /foo/left/master.muted.mov -i /foo/right/master.muted.mov -aspect 32:9 -y -filter_complex '[2:v]setpts=PTS-STARTPTS,pad=iw*2:ih:color=white,framerate=30[l];[3:v]setpts=PTS-STARTPTS[r];[l][r]overlay=x=W-w:shortest=1[vout]' -map [vout] -shortest /foo/central/master.mp4

The leak goes away.

ffmpeg version 7.1 Copyright (c) 2000-2024 the FFmpeg developers
built with gcc 11 (Ubuntu 11.4.0-1ubuntu1~22.04)
configuration: --prefix=/usr/local/ic-ffmpeg-7.1.0 --extra-cflags=-I/usr/local/ic-ffmpeg-7.1.0/include --extra-ldflags=-L/usr/local/ic-ffmpeg-7.1.0/lib --bindir=/usr/local/ic-ffmpeg-7.1.0/bin --extra-libs=-ldl --ld=g++ --enable-gpl --enable-gnutls --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree --enable-frei0r
libavutil      59. 39.100 / 59. 39.100
libavcodec     61. 19.100 / 61. 19.100
libavformat    61.  7.100 / 61.  7.100
libavdevice    61.  3.100 / 61.  3.100
libavfilter    10.  4.100 / 10.  4.100
libswscale      8.  3.100 /  8.  3.100
libswresample   5.  3.100 /  5.  3.100
libpostproc    58.  3.100 / 58.  3.100

Change History (4)

comment:1 by Alfredo Di Napoli, 3 months ago

Summary: anull filter consumes an apparently abound quantity of memoryanull filter consumes an apparently unbound quantity of memory

comment:2 by MasterQuestionable, 3 months ago

Cc: MasterQuestionable added
Component: undeterminedavfilter
Keywords: anull added
Summary: anull filter consumes an apparently unbound quantity of memory"anull" insensibly eating memory

͏    Refactored:
#1:
͏    ffmpeg -i "left" -i "right" -i "left.muted.mov" -i "right.muted.mov" -aspect 32:9 -y -lavfi "[1:1]anull[hms-1-1]" -lavfi "[0:1]anull[hms-0-1]" -lavfi "[2:v]setpts=(( PTS - STARTPTS )),pad=(( iw * 2 )):ih:color=white,framerate=30[l]; [3:v]setpts=(( PTS - STARTPTS ))[r]; [l][r]overlay=x=(( W - w )):shortest=1[vout]" -map [vout] -map [hms-1-1] -map [hms-0-1] -shortest "central.mp4"
#2:
͏    ffmpeg -i "left" -i "right" -i "left.muted.mov" -i "right.muted.mov" -aspect 32:9 -y -lavfi "[2:v]setpts=(( PTS - STARTPTS )),pad=(( iw * 2 )):ih:color=white,framerate=30[l]; [3:v]setpts=(( PTS - STARTPTS ))[r]; [l][r]overlay=x=(( W - w )):shortest=1[vout]" -map [vout] -shortest "central.mp4"

͏    Interpreted "filter_complex" common:
[[

    [2:v]setpts=(( PTS - STARTPTS )),
    pad=(( iw * 2 )):ih:color=white,
    framerate=30[l];
    [3:v]setpts=(( PTS - STARTPTS ))[r];

    [l][r]overlay=x=(( W - w )):shortest=1[vout]

]]

͏    Example #2 didn't include the problematic audio.
͏    Would the problem reproduce just with the audio?

͏    Try removing excessive options to ascertain the minimal one.
͏    E.g.
͏    ffmpeg -v debug -hide_banner -nostdin -nostats -i "left" -i "right" -c:a aac -f null -
͏    ffmpeg -y -v debug -hide_banner -nostdin -nostats -i "left" -f mp4 "/dev/null"

Last edited 3 months ago by MasterQuestionable (previous) (diff)

comment:3 by Alfredo Di Napoli, 3 months ago

Hello there,

Thank you so much for looking into this.

Some (hopefully) extra pointers to track down the issue: I was able to reproduce the problem using the refactored command #1 and using the same input file for all the -i in the command (which also rules out the "muted" argument, i.e. it doesn't matter).

It's also worth pointing out that the issue starts at around frame 130 of my transcoding (~ after 30 seconds of processed video).

The input file is 76MB long and is nothing special (is a piece of a YoutTube video), which I'm happy to attach if the attachments supports such a large file.

comment:4 by MasterQuestionable, 3 months ago

͏    Must include video to reproduce?
͏    Is the video filter-chain relevant?

͏    Try "testsrc" alike as input source? (`-f lavfi -i "..."`)
͏    See:
͏    https://ffmpeg.org/ffmpeg-filters.html#testsrc
͏    https://ffmpeg.org/ffmpeg-filters.html#anullsrc

͏    What about adding "-map 0:1 -map 1:1" in previous example #2?


͏    I tend to avoid processing large files.
͏    You may leave the YouTube video link whatsoever.

Note: See TracTickets for help on using tickets.