Home

Awesome

FFmpeg Docker image

Docker Stars Docker pulls Docker Automated build Github Container Registry Images gitlab pipeline status Azure Build Status

This project prepares a minimalist Docker image with FFmpeg. It compiles FFmpeg from sources following instructions from the Compilation Guide.

You can install the latest build of this image by running docker pull jrottenberg/ffmpeg:${VERSION}-${VARIANT} or docker pull ghcr.io/jrottenberg/ffmpeg:${VERSION}-${VARIANT}.

This image can be used as a base for an encoding farm.

Builds / Avaliabvle Docker Containers

There are different builds available: Below is a table that provides examples for the nomenclature:

ffmpeg-<version>-<os variant and version>

image nameOS verffmpeg vervariantdescription
ffmpeg-7.1-ubuntu240424.046.x - 7.xubuntuexternal libraries are installed from os packages, and ffmpeg is built from source. See Ubunu Compilation Guide for details on this.
ffmpeg-7.1-ubuntu2404-edge24.046.x - 7.xubuntulibs and ffmpeg are built from source. See Ubunu Compilation Guide for details on this.
ffmpeg-7.1-vaapi240424.046.x - 7.xubuntulike: ubuntu2404 but enables: Video Acceleration API (VAAPI) in ffmpeg
ffmpeg-7.1-nvidia2204-edge22.046.x - 7.xubuntuBuilt w/ NVIDIA's hardware-accelerated encoding and decoding APIs enabled
ffmpeg-7.1-alpine3203.206.x - 7.xalpinevendor libs, but ffmpeg is built from source
ffmpeg-7.1-scratch3.206.x - 7.xalpinevendor libs, and ffmpeg are built from source. Also we make the distro as small as possible by not installing any packages in base and striping symbols of installed libs

ffmpeg <version> can be one of the following: 6.1, 7.0, 7.1 with the above table.

Note: The current versions of ffmpeg supported are anything newer than 3 years old and not exceeded the end-of-life

<details><summary>Here are some additional older builds</summary> </details>

Philosophy behind the different builds

ubuntu2404 We chose Ubuntu 24.04 because it is the LTS ( Long Term Support ) build of Ubuntu. We used the ffmpeg support libraries from the Ubuntu distrobution where possible. Example: we use 'libx264-dev' as the package to install. We do not tie it to a version. This way when its time to update from 24.04 to 26.04 we can simply update the base Docker template for ubuntu. This will make updating the OS easier as time goes on.

ubuntu2404-edge This image is just like the above ubuntu2404 container image, except we build all of the ffmpeg support libraries. This is in the spirit of the original intent of this project jrottenberg/ffmpeg alltogether. Building everything that ffmpeg needs, and ffmpeg itself from source. This gives us the most control over all of the details of release. The drawback of this is that its much harder to keep updated. The thought process of having both 'Ubuntu-2404' and 'Ubuntu-2404-edge' is that it makes updating the OS easier over time.

vaapi2404 This release is like also ubuntu2404 but enables: Video Acceleration API (VAAPI) when building ffmpeg

nvidia2204-edge This release is like also ubuntu2404 but enables: NVIDIA's hardware-accelerated encoding and decoding APIs enabled

alpine320 alpine uses the os vendor libs, but ffmpeg is built from source.

scratch Scratch is also an alpine image. We build the vendor libs, and ffmpeg from source. Also we make the distro as small as possible by not installing any packages in base and striping symbols of installed libs.

Generate list of recent Docker Container Images

You can use the following command to generate a list of current images:

$ python3 -mvenv .venv
$ source .venv/bin/activate
$ pip install requests
$ python3 ./generate-list-of-recent-images.py > list_of_recent_images.txt
$ deactivate
$ rm -rf .venv
$ less list_of_recent_images.txt

If you want to compare the one you have locally, use the following command:

$ docker images | grep ffmpeg | sort | awk '{print $1 ":" $2 "\t" $7 $8}'

Please use Github issues to report any bug or missing feature.

Test

ffmpeg version N-98740-ga72d529 Copyright (c) 2000-2020 the FFmpeg developers
  built with gcc 7 (Ubuntu 7.5.0-3ubuntu1~18.04)
  configuration: --disable-debug --disable-doc --disable-ffplay --enable-shared --enable-avresample --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-gpl --enable-libass --enable-fontconfig --enable-libfreetype --enable-libvidstab --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libxcb --enable-libx265 --enable-libxvid --enable-libx264 --enable-nonfree --enable-openssl --enable-libfdk_aac --enable-postproc --enable-small --enable-version3 --enable-libbluray --enable-libzmq --extra-libs=-ldl --prefix=/opt/ffmpeg --enable-libopenjpeg --enable-libkvazaar --enable-libaom --extra-libs=-lpthread --enable-libsrt --enable-libaribb24 --enable-vaapi --extra-cflags=-I/opt/ffmpeg/include --extra-ldflags=-L/opt/ffmpeg/lib
  libavutil      56. 58.100 / 56. 58.100
  libavcodec     58.100.100 / 58.100.100
  libavformat    58. 51.100 / 58. 51.100
  libavdevice    58. 11.101 / 58. 11.101
  libavfilter     7. 87.100 /  7. 87.100
  libavresample   4.  0.  0 /  4.  0.  0
  libswscale      5.  8.100 /  5.  8.100
  libswresample   3.  8.100 /  3.  8.100
  libpostproc    55.  8.100 / 55.  8.100

  configuration:
    --disable-debug
    --disable-doc
    --disable-ffplay
    --enable-shared
    --enable-avresample
    --enable-libopencore-amrnb
    --enable-libopencore-amrwb
    --enable-gpl
    --enable-libass
    --enable-fontconfig
    --enable-libfreetype
    --enable-libvidstab
    --enable-libmp3lame
    --enable-libopus
    --enable-libtheora
    --enable-libvorbis
    --enable-libvpx
    --enable-libwebp
    --enable-libxcb
    --enable-libx265
    --enable-libxvid
    --enable-libx264
    --enable-nonfree
    --enable-openssl
    --enable-libfdk_aac
    --enable-postproc
    --enable-small
    --enable-version3
    --enable-libbluray
    --enable-libzmq
    --extra-libs=-ldl
    --prefix=/opt/ffmpeg
    --enable-libopenjpeg
    --enable-libkvazaar
    --enable-libaom
    --extra-libs=-lpthread
    --enable-libsrt
    --enable-libaribb24
    --enable-vaapi
    --extra-cflags=-I/opt/ffmpeg/include
    --extra-ldflags=-L/opt/ffmpeg/lib

Capture output from the container to the host running the command

 docker run jrottenberg/ffmpeg:4.4-alpine \
            -i http://url/to/media.mp4 \
            -stats \
            $ffmpeg_options  - > out.mp4

Examples

Extract 5s @00:49:42 into a GIF

 docker run jrottenberg/ffmpeg:4.4-alpine -stats  \
        -i http://archive.org/download/thethreeagesbusterkeaton/Buster.Keaton.The.Three.Ages.ogv \
        -loop 0  \
        -final_delay 500 -c:v gif -f gif -ss 00:49:42 -t 5 - > trow_ball.gif

Convert 10bits MKV into a 10Bits MP4

 docker run -v $(pwd):$(pwd) -w $(pwd) jrottenberg/ffmpeg:4.4-scratch \
        -stats \
        -i http://www.jell.yfish.us/media/jellyfish-20-mbps-hd-hevc-10bit.mkv \
        -c:v libx265 -pix_fmt yuv420p10 \
        -t 5 -f mp4 test.mp4

The image has been compiled with X265 Multilib. Use the pixel format switch to change the number of bits per pixel by suffixing it with 10 for 10bits or 12 for 12bits.

Convert a local GIF into a mp4

Let's assume original.gif is located in the current directory :

 docker run -v $(pwd):$(pwd) -w $(pwd)\
        jrottenberg/ffmpeg:4.4-scratch -stats \
        -i original.gif \
        original-converted.mp4

Use ZeroMQ to toggle filter value on-fly

Let's start some process continuously writing some radio music, and listen it:

docker run --rm -d -v $(pwd):$(pwd) -w $(pwd) -p 11235:11235 \
        --name radio-writer jrottenberg/ffmpeg:4.4-alpine \
        -i http://radio.casse-tete.solutions/salut-radio-64.mp3 \
        -filter_complex '[0:a]volume@vol=1,azmq=bind_address=tcp\\\://0.0.0.0\\\:11235[out]' \
        -map '[out]' ./salut-radio.mp3

docker run -it -v $(pwd):$(pwd) -w $(pwd) --entrypoint=ffprobe jrottenberg/ffmpeg:4.4-alpine -v quiet  -show_streams salut-radio.mp3

Now, just toggle its volume on-fly, and hear how it changes:

docker run --rm --network=host --entrypoint sh jrottenberg/ffmpeg:4.4-ubuntu -c \
        'echo "volume@vol volume 2" | zmqsend -b tcp://127.0.0.1:11235'

Send a stream over SRT

Let's send video.mp4 to srt-listener on port 9000 over SRT protocol.

docker run -v $(pwd):$(pwd) jrottenberg/ffmpeg:4.4-centos \
       -re -i $(pwd)/video.mp4 -acodec copy -vcodec copy -f mpegts srt://srt-listener:9000?pkt_size=1316

Use hardware acceleration enabled build

Thanks to qmfrederik for the vaapi ubuntu based variant

jrottenberg/ffmpeg:vaapi or jrottenberg/ffmpeg:${VERSION}-vaapi

docker run --device /dev/dri:/dev/dri -v $(pwd):$(pwd) -w $(pwd) jrottenberg/ffmpeg:4.4-vaapi [...]

Use nvidia hardware acceleration enabled build

Thanks to ShaulMyplay for the nvidia based variant

Supports nvenc only on all ffmpeg versions, and hardware decoding and scaling on ffmpeg >= 4.0

Hardware encoding only example:

docker run --runtime=nvidia jrottenberg/ffmpeg:4.4-nvidia -i INPUT -c:v nvenc_h264 -preset hq OUTPUT Full hardware acceleration example: docker run --runtime=nvidia jrottenberg/ffmpeg:4.4-nvidia -hwaccel cuvid -c:v h264_cuvid -i INPUT -vf scale_npp=-1:720 -c:v h264_nvenc -preset slow OUTPUT

See what's inside the beast
docker run -it --entrypoint='bash' jrottenberg/ffmpeg:7.1-ubuntu2404
for i in ogg amr vorbis theora mp3lame opus vpx xvid fdk x264 x265;do echo $i; find /usr/local/ -name *$i*;done

Libs are in /lib in alpine.

docker run -it --entrypoint='sh' jrottenberg/ffmpeg:7.1-alpine320
for i in ogg amr vorbis theora mp3lame opus vpx xvid fdk x264 x265;do echo $i; find /lib/ -name *$i*;done

FFMPEG Supported Libraries

The following libraries are used by FFMPEG. The version number and release date are provided along with the license information. These version numbers are for the lib source builds, which are 'ubuntu2404-edge' and 'foo'. These libs are included in the package images as well, but the version numbers might vary slightly.

LibrariesVersionRelease DateLicense
ffmpeg7.1GNU Lesser General Public License (LGPL) version 2.1
libogg1.3.408-2019BSD-style license
libopencore-amr0.1.608-2022Apache License

See generate-source-of-truth-ffmpeg-versions.py to update a version

FFMPEG Supported Libraries

The following libraries are used by FFMPEG. The version number and release date are provided along with the license information. These version numbers are for the lib source builds, which are 'ubuntu2404-edge' and 'foo'. These libs are included in the package images as well, but the version numbers might vary slightly.

LibrariesVersionRelease DateDownload SourceChecksumLicense
libopencore-amr0.1.62022-08-01opencore-amr-0.1.6.tar.gzNoApache License
libx26420191217-2245-stable2019-12-17x264-snapshot-20191217-2245-stable.tar.bz2NoGNU General Public License (GPL) version 2
libx2654.02024-09-13x265_4.0.tar.gzNoGNU General Public License (GPL) version 2
libogg1.3.52021-06-04libogg-1.3.5.tar.gzNoBSD-style license
libopus1.5.22024-04-12opus-1.5.2.tar.gzYesBSD-style license
libvorbis1.3.72020-07-04libvorbis-1.3.7.tar.gzYesBSD-style license
libvpx1.14.12024-05-30NoBSD-style license
libwebp1.4.02024-04-13libwebp-1.4.0.tar.gzNoBSD-style license
libmp3lame3.1002017-10-13lame-3.100.tar.gzNoGNU Lesser General Public License (LGPL) version 2.1
libxvid1.3.72019xvidcore-1.3.7.tar.gzNoGNU General Public Licence (GPL) version 2
libfdk-aac2.0.32023-12-21fdk-aac-2.0.3.tar.gzNoLiberal but not a license of patented technologies
openjpeg2.5.22024-02-28openjpeg-2.5.2.tar.gzNoBSD-style license
freetype2.13.32024-08-12freetype-2.13.3.tar.gzNoGNU General Public License (GPL) version 2
libvidstab1.1.12022-05-30vid.stab-1.1.1.tar.gzNoGNU General Public License (GPL) version 2
fontconfig2.15.02023-12-22fontconfig-2.15.0.tar.gzNo
kvazaar2.3.12024-04-10kvazaar-2.3.1.tar.gzNoBSD 3-Clause
aom3.10.02024-08-01NoAlliance for Open Media
nvidia-codec-headers12.2.72.02024-03-31nv-codec-headers-12.2.72.0.tar.gzNo
libsvtav12.2.12024-08-01SVT-AV1-v2.2.1.tar.gzNoBSD 3-Clause Clear License
xproto7.0.312016-09-23xproto-7.0.31.tar.gzNoThe MIT License
libpthread-stubs0.52023-07-18libpthread-stubs-0.5.tar.xzNoThe MIT License
libbluray1.3.42022-11-26libbluray-1.3.4.tar.bz2NoGNU General Public License (GPL) version 2
libzmq4.3.52023-10-9zeromq-4.3.5.tar.gzNoMozilla Public License (MPL) version 2.0
libaribb241.0.32014-08-18aribb24-v1.0.3.tar.gzNoGNU Lesser General Public License (LGPL) version 2.1 or newer
zimg3.0.52023-6-30zimg-3.0.5.tar.gzNoWTFPL
libtheora1.1.12010-01-25libtheora-1.1.1.tar.gzNoBSD-style license
libsrt1.5.32023-09-07srt-v1.5.3.tar.gzNoMozilla Public License (MPL) version 2.0
libvmaf3.0.02023-12-07vmaf-v3.0.0.tar.gzNoBSD-2-Clause
ffmpeg-7.17.12024-09-30ffmpeg-7.1.tar.bz2NoGNU Lesser General Public License (LGPL) version 2.1
ffmpeg-7.07.02024-04-05ffmpeg-7.0.tar.bz2NoGNU Lesser General Public License (LGPL) version 2.1
ffmpeg-6.16.12023-11-11ffmpeg-6.1.tar.bz2NoGNU Lesser General Public License (LGPL) version 2.1

Contribute

See the contributing guide

Legal

Those docker images use code of <a href=http://ffmpeg.org>FFmpeg</a> licensed under the <a href=http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html>LGPLv2.1</a> and their source can be downloaded on <a href=https://github.com/jrottenberg/ffmpeg>github.com/jrottenberg/ffmpeg</a>.