Practically all FFmpeg buildpacks we have found simply contain static binaries in their repository and not much else. This is an issue regarding maintainability and security. This is why this buildpack exists. It provides a way from official FFmpeg source code to binaries accessible via
PATH environment variable in Heroku slug running your application.
You might ask why not to use some Heroku Add-on or other third-party service like typical Heroku user? We think they are expensive, slow or limited for what we need.
Add buildpack to your existing app:
heroku buildpacks:add https://github.com/kontentcore/heroku-buildpack-ffmpeg
If you want to see changes immediately, create an empty commit:
git commit --allow-empty -m 'Add FFmpeg buildpack'
See for yourself:
git push heroku master # … heroku run bash # Running bash on ⬢ kc-ffmpeg... up, run.2418 (Hobby) ffmpeg -version # ffmpeg version 3.3.2 Copyright (c) 2000-2017 the FFmpeg developers # built with gcc 5.4.0 (Ubuntu 5.4.0-6ubuntu1~16.04.4) 20160609 # configuration: --prefix=/app/.ffmpeg --yasmexe=/app/.yasm/bin/yasm # libavutil 55. 58.100 / 55. 58.100 # libavcodec 57. 89.100 / 57. 89.100 # libavformat 57. 71.100 / 57. 71.100 # libavdevice 57. 6.100 / 57. 6.100 # libavfilter 6. 82.100 / 6. 82.100 # libswscale 4. 6.100 / 4. 6.100 # libswresample 2. 7.100 / 2. 7.100
As you can
ffmpeg and other FFmpeg binaries are accessible via
PATH environment variable.
We utilize only
bin/compile script expected by Heroku Buildpack API. In this phase we download pre-build binaries from AWS S3 for specified FFmpeg version and Heroku stack. Building FFmpeg from sources during this phase is something that would be great but it is not implemented.
Heroku stack your app is running on is something you have to configure yourself.
Desired FFmpeg version cat be set by
FFMPEG_VERSION config var. It defaults to whatever we have seen as the last stable version which is 3.3.2 as of this writing.
The AWS S3 bucket can be overridden by setting
FFMPEG_S3_BUCKET config var. It defaults to
kc-heroku-buildpack-binaries. We expect to find binary archives with these keys:
We use Docker with Heroku-16 build image. It is simple and straightforward.
The code itself should build FFmpeg on Cedar-14 but it requires more complicated setup. We have no need for it, so we do not support it.
Run the following to build and publish binary archive:
docker build -t heroku-buildpack-ffmpeg . docker run \ -e "AWS_ACCESS_KEY_ID=$(aws configure get aws_access_key_id)" -e "AWS_SECRET_ACCESS_KEY=$(aws configure get aws_secret_access_key)" \ heroku-buildpack-ffmpeg
We use AWS CLI in the example above, but you can use anything that suits you. However,
AWS_SECRET_ACCESS_KEY are required. There are other environment variables which affect the build process and were described before:
Copy the snippet above into CLI.