|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
[2021-08-11 12:45 UTC] cmb@php.net
-Status: Open
+Status: Feedback
-Assigned To:
+Assigned To: cmb
[2021-08-11 12:45 UTC] cmb@php.net
[2021-08-22 04:22 UTC] php-bugs at lists dot php dot net
[2021-09-02 11:43 UTC] bruno dot premont at restena dot lu
-Status: No Feedback
+Status: Closed
[2021-09-02 11:43 UTC] bruno dot premont at restena dot lu
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Fri Oct 24 18:00:01 2025 UTC |
Description: ------------ Loading extensions on a per-pool basis make the extension usable only a single time per worker process. Loading the extension globally for PHP via php.ini works fine. Working setup: php.ini: extension=radius.so Failing setup: php-fpm.conf [pool] php_admin_value[extension] = radius.so On failing setup following test-script fails with radius_auth_open: undefined function for second request. Easiest testing is pm=ondemand, long enough pm.process_idle_timeout and two subsequent requests. First request works, second one fails. The module is still reported as loaded and its functions are still returned by get_extension_funcs() even though they are undefined. Test script: --------------- <?php date_default_timezone_set('Europe/Luxembourg'); header('Content-Type: text/plain; charset=UTF-8'); printf("Checking for 'radius' extension: %s\n", extension_loaded('radius') ? 'loaded' : 'missing'); $fa = get_extension_funcs('radius'); printf("Checking for 'radius' extension functions:%d\n", $fa === false ? -1 : count($fa)); if ($fa !== false) foreach ($fa as $faf) printf("\t%s(): %s\n", $faf, function_exists($faf) ? 'exists' : 'missing'); flush(); printf("Calling radius_auth_open():\n");flush(); $rh = function_exists('radius_auth_open') ? radius_auth_open() : false; printf("\t%s\n", $rh === false ? 'false' : 'resource'); if ($rh) { // use $rh ... printf("Calling radius_close()\n");flush(); $r = radius_close($rh); printf("\t%s\n", $r === true ? 'success' : 'failed'); } ?> Expected result: ---------------- The radius functions should be usable for each request and not only the ones that happens to be the first request processed by the respective worker. Actual result: -------------- First request works, second and subsequent requests to same worker process fail with undefined function on any call to extension functions. extension_loaded() and get_extension_funcs() still return same information for subsequent requests as they do for the first request.