From: ilya77 at gmail dot com Operating system: Windows XP PHP version: 5.0.2 PHP Bug Type: Program Execution Bug description: proc_open() / proc_close() leak handles on Windows XP
Description: ------------ I have a scheduler script, which constantly runs in the background, invokes processes, and pipes their output back to stdout. It seems that proc_open() or proc_close() call leaks handles on Windows platform (I'm running PHP 5.0.2). In the example code, the handles count would increment by 1 each time invoke() is called, in other places I saw similar code leak 4 handles at once during each iteration. Reproduce code: --------------- while(1) { echo("---\n"); invoke(); sleep(5); } function invoke() { $commandLine = "echo hello"; $fileDescriptors = array( 1 => array("pipe", "w"), 2 => array("pipe", "w") ); $pipes = array(); $processHandle = proc_open($commandLine, $fileDescriptors, $pipes); if (is_resource($processHandle)) { foreach($pipes as $pipeID => $pipeHandle) fclose($pipeHandle); proc_close($processHandle); } } Expected result: ---------------- I expected the handle count to increment by X, and decrement by X after the process completes. (where it's logical to assume that X = number of pipes + 1 for the child process handle) Actual result: -------------- In fact, the handles count (in windows task manager) for the php.exe process running the script incremented by 1 each time invoke() in the example code was executed. -- Edit bug report at http://bugs.php.net/?id=30743&edit=1 -- Try a CVS snapshot (php4): http://bugs.php.net/fix.php?id=30743&r=trysnapshot4 Try a CVS snapshot (php5.0): http://bugs.php.net/fix.php?id=30743&r=trysnapshot50 Try a CVS snapshot (php5.1): http://bugs.php.net/fix.php?id=30743&r=trysnapshot51 Fixed in CVS: http://bugs.php.net/fix.php?id=30743&r=fixedcvs Fixed in release: http://bugs.php.net/fix.php?id=30743&r=alreadyfixed Need backtrace: http://bugs.php.net/fix.php?id=30743&r=needtrace Need Reproduce Script: http://bugs.php.net/fix.php?id=30743&r=needscript Try newer version: http://bugs.php.net/fix.php?id=30743&r=oldversion Not developer issue: http://bugs.php.net/fix.php?id=30743&r=support Expected behavior: http://bugs.php.net/fix.php?id=30743&r=notwrong Not enough info: http://bugs.php.net/fix.php?id=30743&r=notenoughinfo Submitted twice: http://bugs.php.net/fix.php?id=30743&r=submittedtwice register_globals: http://bugs.php.net/fix.php?id=30743&r=globals PHP 3 support discontinued: http://bugs.php.net/fix.php?id=30743&r=php3 Daylight Savings: http://bugs.php.net/fix.php?id=30743&r=dst IIS Stability: http://bugs.php.net/fix.php?id=30743&r=isapi Install GNU Sed: http://bugs.php.net/fix.php?id=30743&r=gnused Floating point limitations: http://bugs.php.net/fix.php?id=30743&r=float MySQL Configuration Error: http://bugs.php.net/fix.php?id=30743&r=mysqlcfg