$customer uses Zend_Cache in their codebase – and I noticed that every so often a page request would take ~5 seeconds (for no apparent reason), while normally they take < 1 second …
Some rummaging and profiling with xdebug showed that some requests looked like :
data:image/s3,"s3://crabby-images/aba08/aba08ce6250618214eb103b336697aa704c0c1c2" alt="xdebug profiling output - note lots of zend_cache stuff xdebug profiling output - note lots of zend_cache stuff"
Note how there are 25,000 or so calls for various Zend_Cache_Backend_File thingys (fetch meta data, load contents, flock etc etc).
This alternative rendering might make it more clear – especially when compared with the image afterwards :
data:image/s3,"s3://crabby-images/1cc2b/1cc2bd75e5ec3038184249b1b2bcdba1c8abb8cb" alt="zend cache dominating the call map zend cache dominating the call map"
while a normal request should look more like :
data:image/s3,"s3://crabby-images/5427a/5427a30c1793ba8781539a983d5c392e26d7d946" alt="a "normal" request - note Zend_Cache is not dominating a "normal" request - note Zend_Cache is not dominating"
Zend_Cache has a ‘automatic_cleaning_mode’ frontend parameter – which is by default set to 10 (i.e. 10% of all write requests to the cache result in it checking if there is anything to garbage collect/clean). Since we’re nearly always writing something to the cache, this results in 10% of requests triggering the cleaning logic.
SeeĀ http://framework.zend.com/manual/en/zend.cache.frontends.html.
The cleaning is now run via a cron job something like :
$cache_instance->clean(Zend_Cache::CLEANING_MODE_OLD);