ID: 48643 User updated by: z...@php.net Reported By: z...@php.net Status: Open Bug Type: SPL related Operating System: Linux (Ubuntu) PHP Version: 5.2CVS-2009-06-22 (CVS) New Comment:
Looking backwards through PHP builds I have currently narrowed this down to a change that went in to PHP 5.3 somewhere between the 12th June 2008 and the 1st July 2008. Previous Comments: ------------------------------------------------------------------------ [2009-06-23 12:13:49] robin_fernandes at uk dot ibm dot com Below is a simplified testcase which I think exposes the same leak. '/manyFiles' is a directory containing 10000 files. <?php $rii = new RecursiveIteratorIterator( new RecursiveDirectoryIterator('/manyFiles') ); function noop() {} echo "noop call in loop (no leak) : "; foreach ($rii as $v) { noop($v); } echo memory_get_usage() . PHP_EOL; echo "strlen call in loop (leak on 53) : "; foreach ($rii as $v) { strlen($v); } echo memory_get_usage() . PHP_EOL; ?> Output on php52: noop call in loop (no leak) : 66176 strlen call in loop (leak on 53) : 66176 Output on php53: noop call in loop (no leak) : 337448 strlen call in loop (leak on 53) : 6028496 ------------------------------------------------------------------------ [2009-06-22 14:33:05] z...@php.net I tested with PHP 5.2 but do not see the same issue. I believe this is specific to PHP 5.3. ------------------------------------------------------------------------ [2009-06-22 12:32:02] z...@php.net By the way, I traced the memory consumption using xdebug: xdebug.auto_trace = on; xdebug.show_mem_delta = on; The first few lines are here http://pastebin.ca/1469804 This makes it look more like a bug with the way the accept() method is invoked inside PhptFilterIterator. ------------------------------------------------------------------------ [2009-06-22 11:41:59] z...@php.net Description: ------------ An excessive about of memory is used when a class which extends FilterIterator is used to filter for certain file types when scanning a source tree. Reproduce code: --------------- A small benchmark is provided in the tar file here:http://filebin.ca/okgvtt/memcheck.tar The file contains three tests which all use code in Util.php. To run the tests edit the shell script memcheck to add the top level directory of a PHP source tree as input to each test. Then just execute the shell script. The benchmarks produce a list of directories which contain .phpt files, the memory usage when the class PhptFilterIterator is used is 20 times higher than the other two methods. Expected result: ---------------- Would expect the memory usage to be similar. Actual result: -------------- Memory usage is 20 times higher. ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=48643&edit=1