|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #72666 touch(): stat cache clearing inconsistent between file:// paths and plain paths
Submitted: 2016-07-25 07:37 UTC Modified: 2022-02-13 03:02 UTC
From: phofstetter at sensational dot ch Assigned:
Status: Open Package: Streams related
PHP Version: 7.1.0beta1 OS: MacOS X and Linux
Private report: No CVE-ID: None
View Add Comment Developer Edit
Anyone can comment on a bug. Have a simpler test case? Does it work for you on a different platform? Let us know!
Just going to say 'Me too!'? Don't clutter the database with that please — but make sure to vote on the bug!
Your email address:
Solve the problem:
39 - 19 = ?
Subscribe to this entry?
Further comment on this bug is unnecessary.
 [2016-07-25 07:37 UTC] phofstetter at sensational dot ch
When calling touch() on a plain path, the stat cache doesn't get cleared. However, when calling touch() on a 'file://' URL, the stat cache gets cleared by virtue of `php_plain_files_metadata` which clears the stat cache after all operations.

This leads to the behaviour as shown in the test script (output available here:

Furthermore: fopen(), fwrite(), fclose() does not clear the stat cache in either case and neither does file_put_contents().

I would create a PR to fix the touch() case, but in general, it's probably worth reconsidering the usefulness of the stat-cache these days. Even over an NFS link, when doing nothing but stat()'ing, you still only lose about 10% performance if you call clearstatcache() after every stat().

Plus, the cache really only helps when you continuously stat() the same file within the same request, which probably isn't correct application behaviour anyways.

So in general, I would propose to actually kill the stat cache which would fix this inconsistency as well :-)

Test script:

// doesn't update realpath cache
touch('/tmp/foo', 1);

// does update the realpath cache
touch('file:///tmp/foo', 1);

Expected result:

Actual result:


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2016-07-25 11:02 UTC]
As mentioned on ML, I'd doubt the removal is justified. The most of usage scenarios only profit from the caching, while in other cases cache can be explicitly reset. I/O is one of the usual bottlenecks, even today. So more like expected behavior.

 [2016-07-25 11:10 UTC] phofstetter at sensational dot ch
ok. Thank you. 

I'll prepare a PR then that clears the cache when touch() is used.

What about clearing the cache when fopen() is used with any of the writable flags?
 [2021-09-04 19:06 UTC] kevin at lyda dot ie
There are a long list of functions that would need to be updated as this is due to the stat cache. Among the functions that would need to be updated: touch(), fopen(), fread(), fwrite(). The unlink() function already does the update. There's also an argument that exec() and related functions should be updated to invalidate the stat cache.

See bug 28790 for more info and a possible, more reliable, solution.
 [2022-02-13 03:02 UTC]
-Block user comment: No +Block user comment: Yes
PHP Copyright © 2001-2023 The PHP Group
All rights reserved.
Last updated: Sun May 28 17:03:40 2023 UTC