Skip to content

vips_init takes >30 seconds when used /w FPM and dumps FPM core #282

@jardayn

Description

@jardayn

Good day. Started using the library and this package via Intervention Image.

My test setup that let's me replicate it:
1: Apache/PHP 8.4 FPM with 8 workers on a 2 core server.
2: libvips42 vips-8.12.1-Wed on Ubuntu.
3: ffi.enable=true (no preloading).
4: VIPS_CONCURRENCY=1 set in the pool config.
5: env[G_SLICE] = always-malloc in FPM's config (didn't help)

I use intervention image to convert images.

$image = $this->imageManager->read($stringOrPath);
        $image->scaleDown(width: 1600);

        return $image->toWebp(quality: 80, strip: false);

If I do this in multiple tabs at the same time - some requests hang and get killed by FPM's timeout. (35s)
The cause for the hang is: vips_init() /var/www/html/vendor/jcupitt/vips/src/FFI.php:321

Maybe I'm doing something wrong?

I'm not calling vips_shutdown, and AFAIK Intervention/mage isn't either.
When the hang happens - the CPU is <20%.

Full stack trace from FPM's slow log:

php8.4-slow.log script_filename = /var/www/html/public/index.php
php8.4-slow.log [0x0000f3563a613e30] vips_init() /var/www/html/vendor/jcupitt/vips/src/FFI.php:321
php8.4-slow.log [0x0000f3563a613cf0] init() /var/www/html/vendor/jcupitt/vips/src/FFI.php:159
php8.4-slow.log [0x0000f3563a613c60] version() /var/www/html/vendor/jcupitt/vips/src/Config.php:149
php8.4-slow.log [0x0000f3563a613bf0] version() /var/www/html/vendor/intervention/image-driver-vips/src/Driver.php:189
php8.4-slow.log [0x0000f3563a613b60] checkHealth() /var/www/html/vendor/intervention/image/src/Drivers/AbstractDriver.php:36
php8.4-slow.log [0x0000f3563a613af0] __construct() /var/www/html/vendor/intervention/image/src/ImageManager.php:126
php8.4-slow.log [0x0000f3563a613a30] resolveDriver() /var/www/html/vendor/intervention/image/src/ImageManager.php:41
php8.4-slow.log [0x0000f3563a613900] withDriver() /var/www/html/application/Services/Images/LocalImageConverter.php:13
php8.4-slow.log [0x0000f3563a613850] createAssetEncodedImage() /var/www/html/application/Models/Model.php:180
php8.4-slow.log [0x0000f3563a613730] uploadAssetImage() /var/www/html/application/Models/Model.php:24
php8.4-slow.log [0x0000f3563a6136a0] uploadImage() /var/www/html/application/Modules/admin/Controllers/ArtistsController.php:464
php8.4-slow.log [0x0000f3563a613560] editAction() /var/www/html/library/Zend/Controller/Action.php:525
php8.4-slow.log [0x0000f3563a613480] dispatch() /var/www/html/library/Zend/Controller/Dispatcher/Standard.php:308
php8.4-slow.log [0x0000f3563a613330] dispatch() /var/www/html/library/Zend/Controller/Front.php:954
php8.4-slow.log [0x0000f3563a613240] dispatch() /var/www/html/library/Zend/Application/Bootstrap/Bootstrap.php:106
php8.4-slow.log [0x0000f3563a613180] run() /var/www/html/library/Zend/Application.php:400
php8.4-slow.log [0x0000f3563a613100] run() /var/www/html/public/index.php:253

Here's what I'm getting when it dies:

Process 18007 (php-fpm8.4) of user 33 dumped core.#012#012Found module linux-vdso.so.1 with build-id: d2d515465437461394f3c49b47dcfe228e7ef1f7#012Found module libaec.so.0 with build-id: 023b197ad848dcdb03b1481e80f6712c4b342abe#012Found module libplds4.so with build-id: b4747b094674f72f3fd4db7befda78a739ce05a6#012Found module libnssutil3.so with build-id: 3761286fb5f0d00ea81e9a76f73c3a87cc900766#012Found module libsz.so.2 with build-id: 887b0a78174d5b4c26092dab0be049312e0d4235#012Found module libnspr4.so with build-id: e82d062346d70bfc5ca6513bcaf62dd769a6bf90#012Found module libplc4.so with build-id: 4bbc66943195bcbf6eb0b0aa285e9254fbe2a9ec#012Found module libsmime3.so with build-id: bc23f6395a7be45ff169c348833139a8419f3571#012Found module libnss3.so with build-id: 81da351271f251e05aa719cd1cd3018d156ef5e9#012Found module libcurl-gnutls.so.4 with build-id: 790f4e925c6ad41e0cc2c888dc494d6cbf12bff2#012Found module libhdf5_serial.so.103 with build-id: a07a188a535a2c969b66112438443d3d07269ee7#012Found module libgdk_pixbuf-2.0.so.0 with build-id: 73888e10a71ef0759622c5ba631e89380213cad4#012Found module libcairo-gobject.so.2 with build-id: b37c38a9d100974f8da6e97c01114fd2da9d4bb6#012Found module libpoppler.so.118 with build-id: 7577b3008e8dc07226f717c7b15cc4979ccd482f#012Found module libcgif.so.0 with build-id: 23905dac3403fd8174df78d1d35594872811bc1e#012Found module libexif.so.12 with build-id: caaf0dcffec806b071d457242864a3b1c63fd16c#012Found module libcfitsio.so.9 with build-id: bfccb4bb7885c764a23f52833bd6a17ff1df061c#012Found module libmatio.so.11 with build-id: 6f625d25d73d9fb557effe50ede32db8b84469f5#012Found module libopenslide.so.0 with build-id: 77936c9bbd0413bcfa4e25495b3fed31da242531#012Found module librsvg-2.so.2 with build-id: 9fe9964bd527126acf95ed719092d65bf38fa702#012Found module libpoppler-glib.so.8 with build-id: 8a754ac0068c0b949f27969ac79015b9d422c8dd#012Found module liborc-0.4.so.0 with build-id: f0fd1f5e26798315eb19b383eec88955c5fa40bc#012Found module libgsf-1.so.114 with build-id: cfddd264e1619bde167275ced96d8bd381fc2fee#012Found module libvips.so.42 with build-id: d3441a8f0239567bb81ba18f16158ff710257a6e#012Found module yuv.so with build-id: 46afce3c21bb667ae099d4ce5381fbefc589d4dc#012Found module ycbcr.so with build-id: 0af08186250e4cbb9c88b42518f9bc0fc2abef17#012Found module xwd.so with build-id: 76d6470d63a6d2f0fb2fb555c75c2860bcd789ff#012Found module xtrn.so with build-id: 1f9234a678de76a2947223e1ff7f93a73aaf4bcc#012Found module xps.so with build-id: 1dd75aa5cf6601db2ef59ef6e63c942bc1293a32#012Found module xpm.so with build-id: 85db7df618373c2fbcf2ad043c28077d575bd3b3#012Found module xcf.so with build-id: 1cf5f2825fdceb1fb4eea18e7dd03efdfc8f70b7#012Found module xc.so with build-id: a899e27eeaea0fa43437776567cebab78a191e15#012Found module xbm.so with build-id: 59291a8d427264503ebf27fdfcdc12b5eb89343d#012Found module x.so with build-id: a663fb5a98117a23267aa985f3f00a1237c1a7b2#012Found module wpg.so with build-id: b10ad2b6c058268d5c036c4cf2e6d42ca65915fe#012Found module libwmflite-0.2.so.7 with build-id: 8c9be2727fa79d54327a04ceda4beae83512390d#012Found module wmf.so with build-id: fd0c57eba3dfced34c35aeb6855483689334ebea#012Found module webp.so with build-id: 8082dafaabaaf464af2fdaa62964ed4363689ae8#012Found module wbmp.so with build-id: 3dc2d7f6c4bf335b196251262c6e845636e05212#012Found module vips.so with build-id: 549cdb8d846efb7595cd9495cf71877c626fef9d#012Found module viff.so with build-id: 6903320fd48418bd24540c95a399a70230c76b40#012Found module video.so with build-id: 8cb29d2cded8a9d691aca0a73871abeb6e568c18#012Found module vid.so with build-id: ca05d79534fad567001441bc074718a43c6e2714#012Found module vicar.so with build-id: 4d492fec9dc430ab11b346687625357f29c977c3#012Found module uyvy.so with build-id: 495a1a3333de806c5419223a70bddd7737964ae7#012Found module url.so with build-id: 39807e350a2bcf281553f7b1466ef1a77a4d3971#012Found module uil.so with build-id: 9811377afa1f10507e8b91d4e19a64b5e8512449#012Found module txt.so with build-id: 279fdcad62306a92a5390fa22fd9fe0507f0d5be#012Found module ttf.so with build-id: 2c5b5f34c183e8719980dce2e06ab41f7f3eff6f#012Found module tim.so with build-id: 11df6d1268ed6e0f7b691e1046e928a7ea066464#012Found module tile.so with build-id: 7865d69d74ef20b3981e0ac226e0d8ce3060ca88#012Found module tiff.so with build-id: a161f0a7939d59a5da9d5d1b13d9ded2ccc8811c#012Found module thumbnail.so with build-id: ac72e9f797d9ee53cd91699491a729107ab08f42#012Found module tga.so with build-id: 2d6d4e4564fc7b193a7358333d37e80207b1aa71#012Found module svg.so with build-id: 27485d6f3191c69757efd313c9181f20231368da#012Found module sun.so with build-id: ec84afed2fbea179d712ef09e8193f12a1ffd5fe#012Found module stegano.so with build-id: a3e3bdcba84652928a3b144f61b765b04f8c1cd6#012Found module sixel.so with build-id: 0445d9bdea000d5e786185f0418e556e947f03b3#012Found module sgi.so with build-id: e1dd7f084c1d5ab88f8255eb7d8590755792c464#012Found module sfw.so with build-id: 94ddaddc0778e1a5c2f5ae7cc4d1eda8ef4b758c#012Found module sct.so with build-id: de4334490a875085dfc71eec5162e2d38dda1c67#012Found module scr.so with build-id: 8e12bbc4bee809bcd8eb81b73a07eb60999ce5a1#012Found module rle.so with build-id: 072178ca2c37803cd8954b31a4622351ec3e9550#012Found module rla.so with build-id: 4cefab143c9d3e9708823316ecdc8d9b206097d7#012Found module rgf.so with build-id: 52a8a47e5e3b2af5a54cdbb93a722d7edba6cf73#012Found module rgb.so with build-id: 3aafbaac01beeac41c8e40e3eab3366a6b406820#012Found module pwp.so with build-id: 50ec00887323158b312b1d78f5cc64ecbee8230f#012Found module psd.so with build-id: 5869b105197bfc6938ed1a6316820a3fdce372b7#012Found module ps3.so with build-id: 083e5cbe744e68b927fab14813f13640b88e2c13#012Found module ps2.so with build-id: 177bc9a647fded2539f135642ee478216a52f09f#012Found module ps.so with build-id: fd6090bf90e4db5b37c565097931a8ac53a87725#012Found module preview.so with build-id: 1e24d238af2e3e1cf2d5f7bab46459274d4adb3e#012Found module pnm.so with build-id: 05b9dbc2517b7e7717cd49e7f1243d12d541b31c#012Found module png.so with build-id: f8b6cf1332f25eb36de0dedfa58cc0e6288ce890#012Found module plasma.so with build-id: 4b371fe5bddc81577027fb1b8839e307a4db515f#012Found module pix.so with build-id: cf6b13c46940c2ba2d599a5f6510e25f87ef01ba#012Found module pict.so with build-id: 90e664ee8822c852257feb74050b99d2fe5fcd20#012Found module pgx.so with build-id: 605d9782f1c73666a43ac72e233aa4b63d79aad4#012Found module pes.so with build-id: daf66c89db4c1e91b201234a65d9ae17a5373498#012Found module pdf.so with build-id: c6d72355c8d3bc4387561464ede7adf2341196da#012Found module pdb.so with build-id: fa8eba8b06ebd96582287c7bdc66ecf71d20f622#012Found module pcx.so with build-id: e7edc42c66846702e4c56f6e125d0a8ec98a15e1#012Found module pcl.so with build-id: 998c56222589d34d149a7cd616721b713bdfbf9a#012Found module pcd.so with build-id: ff6972ddae710843fb9b6d67aef8198f2a1b4503#012Found module pattern.so with build-id: f9c9902abd994c7e045be2d29a73ccc35ce6cc5b#012Found module pango.so with build-id: 668569ecf3f7e577b9f17c1bb1f27f1aae3836ae#012Found module palm.so with build-id: 97209fc7cd983d6bd7973faf6ad6d15660ab1cef#012Found module otb.so with build-id: b2ac8bf76fbeb5ba94e206a07a7404408d502b0d#012Found module null.so with build-id: 59924f621eb4b99779f47c2aef49f2f3399d5261#012Found module mvg.so with build-id: 791798217bea4408da1eb267eb771bde414df715#012Found module mtv.so with build-id: ec7f5eaee037ed762f829be86aa8d729efe1359b#012Found module msl.so with build-id: 2e6d16f75c0f88361a98dc8104955b755a85bcf2#012Found module mpr.so with build-id: 2c5899439c05e46ddf62e0e5080a5252571d9af6#012Found module mpc.so with build-id: be5dbfbb15304297374923cdb26ce91fdcc34dc0#012Found module mono.so with build-id: 3485fdceeafb7df58d94224247ae1099e01d91fe#012Found module miff.so with build-id: e446dc91bb4acc92ac08571f577d3a3ecb180432#012Found module meta.so with build-id: eccf12a997ee47f1d0376eead2657b50e5a26c14#012Found module matte.so with build-id: 0c21e108c8bf948d73f351a2b8da

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions