In comparing the performance of PHP 5.2.5 file_exists calls versus C stat
calls, I discovered via Windows sysinternals
ProcessMonitor that PHP seems to do a stat on each component of a file path.
For example,
file_exists("e:\\wamp\\www\\ra-v2\\system\\application\\libraries\\MY_Controller.php")
appears to stat "E:\wamp", "E:\wamp\www",
etc., finally getting to the file. That compares to doing _stat64 of
"e:\\wamp\\www\\ra-v2\\system\\application\\libraries\\MY_Controller.php" in C,
which just does the stat on the file. The timings
from my tests show the C app finishing in about one-seventh the time, which is
what I would expect from the PHP code doing seven
times as many stat calls.
Assuming my inference about all the stat calls is correct, is there a rationale
for this? If the PHP app I am working on made just
a couple of file_exists calls, I would not bother to ask, but it uses the
CodeIgniter framework which is doing >100 file_exists
calls for each page being accessed, so the affect is very noticeable.
FYI, I poked around the PHP SVN web interface for a while and found
php_check_open_basedir_ex called in plain_wrapper.c, which I
suspect causes the calls, but ran out of steam before confirming the cause of
the behavior.
TIA
--
Scott Nichol
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php