Skip to content
Advertisement

Heroku : FFMpeg installed but php worker can’t find it

Context

I’ve a RabbitMQ’s queue that contains AMQPMessage, those messages are referencing a video that needs to be treated (cut essentially and encoded in x264 also)

Here’s the code that cause the issue (pretty straightforward)

        $ffprobe = FFProbe::create([
            'ffmpeg.binaries'  => '/usr/bin/ffmpeg',
            'ffprobe.binaries' => '/usr/bin/ffprobe',
        ]);

Error Message

TL;DR : Error: "Unable to load FFProbe"

[2019-12-03 14:55:07] messenger.ERROR: Error thrown while handling message AppApiMessageAMQPvideoFFMPEG. Sending for retry #1 using 1000 ms delay. Error: “Unable to load FFProbe” {“message”:”[object] (AppApiMessageAMQPvideoFFMPEG: {})”,”class”:”AppApiMessageAMQPvideoFFMPEG”,”retryCount”:1,”delay”:1000,”error”:”Unable to load FFProbe”,”exception”:”[object] (SymfonyComponentMessengerExceptionHandlerFailedException(code: 0): Unable to load FFProbe at /app/vendor/symfony/messenger/Middleware/HandleMessageMiddleware.php:80, FFMpegExceptionExecutableNotFoundException(code: 0): Unable to load FFProbe at /app/vendor/php-ffmpeg/php-ffmpeg/src/FFMpeg/Driver/FFProbeDriver.php:50, AlchemyBinaryDriverExceptionExecutableNotFoundException(code: 0): Executable not found, proposed : /usr/bin/ffprobe at /app/vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/AbstractBinary.php:160)”} []

Configuration & tests

On Heroku I’ve 2 dynos :

- web $(composer config bin-dir)/heroku-php-nginx -C config/packages/dev/heroku_nginx.conf public/
- worker php bin/console messenger:consume ffmpeg 

On this platform, I’ve also 3 buildpacks, look below, with this specific buildpack :

with a custom buildpack for ffmpeg

To make sure that all is available here’s the results of my checks :

 heroku run "ffmpeg -version" -a project-dev 
Running ffmpeg -version on ⬢ project-dev... up, run.6134 (Hobby)
ffmpeg version N-67574-g9d6ad68 Copyright (c) 2000-2014 the FFmpeg developers
built on Nov 12 2014 11:35:09 with gcc 4.4.3 (Ubuntu 4.4.3-4ubuntu5.1)
configuration: --enable-static --disable-shared --disable-asm --extra-libs=-L/app/vendor/libs/lib --extra-cflags=-I/app/vendor/libs/include --prefix=/app/vendor/ffmpeg --enable-libfdk-aac --enable-nonfree --enable-libx264 --enable-gpl
libavutil      54. 11.100 / 54. 11.100
libavcodec     56. 12.100 / 56. 12.100
libavformat    56. 12.103 / 56. 12.103
libavdevice    56.  2.100 / 56.  2.100
libavfilter     5.  2.103 /  5.  2.103
libswscale      3.  1.101 /  3.  1.101
libswresample   1.  1.100 /  1.  1.100
libpostproc    53.  3.100 / 53.  3.100
 heroku run "ffprobe -version" -a projet-dev
Running ffprobe -version on ⬢ projet-dev... up, run.2357 (Hobby)
ffprobe version N-67574-g9d6ad68 Copyright (c) 2007-2014 the FFmpeg developers
built on Nov 12 2014 11:35:09 with gcc 4.4.3 (Ubuntu 4.4.3-4ubuntu5.1)
configuration: --enable-static --disable-shared --disable-asm --extra-libs=-L/app/vendor/libs/lib --extra-cflags=-I/app/vendor/libs/include --prefix=/app/vendor/ffmpeg --enable-libfdk-aac --enable-nonfree --enable-libx264 --enable-gpl
libavutil      54. 11.100 / 54. 11.100
libavcodec     56. 12.100 / 56. 12.100
libavformat    56. 12.103 / 56. 12.103
libavdevice    56.  2.100 / 56.  2.100
libavfilter     5.  2.103 /  5.  2.103
libswscale      3.  1.101 /  3.  1.101
libswresample   1.  1.100 /  1.  1.100
libpostproc    53.  3.100 / 53.  3.100

All good !

Disclaimer

This code is working well on another platform (handled by kubernetes), so it may need some adjustments with heroku. But can’t find it.

Why this error since my configuration is not showing any missconfigurations? What am I missing here?

Advertisement

Answer

Change to:

    $ffprobe = FFProbe::create([
        'ffmpeg.binaries'  => '/app/vendor/ffmpeg_bundle/ffmpeg/bin/ffmpeg',
        'ffprobe.binaries' => '/app/vendor/ffmpeg_bundle/ffmpeg/bin/ffprobe',
    ]);

You were using /usr/bin/, but your files were not located there.

  • The script edited your PATH to include $HOME/vendor/ffmpeg_bundle/ffmpeg/bin and --prefix is set to /app/vendor/ffmpeg, so I suspect this is the location of the files.

  • Run whereis ffmpeg. If ffmpeg is in your PATH it will give you the location.

  • Why use ffmpeg from 2014? Development is very active so you’re missing out on thousands of updates. Also, I recommend avoiding compiling without --disable-asm if possible (same for x264).

User contributions licensed under: CC BY-SA
9 People found this is helpful
Advertisement