Edit report at https://bugs.php.net/bug.php?id=35326&edit=1

 ID:                 35326
 Comment by:         gustavo dot straube at gmail dot com
 Reported by:        bugs dot php dot net at chsc dot dk
 Summary:            Concurrency issue with recursive mkdir
 Status:             Not a bug
 Type:               Feature/Change Request
 Package:            *General Issues
 Operating System:   Linux
 PHP Version:        5.1.6
 Block user comment: N
 Private report:     N

 New Comment:

> We don't need a locking mechanism. If the creation of a directory fails, we 
> just need to check if it exists anyway [...]

In the application I experienced this bug, I do have a condition before the 
directory creation.

1. if (!is_dir($path))
2.   mkdir($path, 0755, true);

If I have two concurrent process ("A" and "B") running the code in this order 
(process - line):

A - 1
B - 1
B - 2
A - 2

When process "A" verified the directory existence, it really didn't exist.


Previous Comments:
------------------------------------------------------------------------
[2013-10-30 08:49:24] bugs dot php dot net at chsc dot dk

> To create the right locking mechanism to avoid such issue to happen

We don't need a locking mechanism. If the creation of a directory fails, we 
just need to check if it exists anyway (i.e. it has been created by a 
concurrent thread). If it does, we can proceed to create the subdirectories.

------------------------------------------------------------------------
[2013-10-01 04:52:05] paj...@php.net

Update the status.

And adding a small note about "why is it not a php bug", what is described here 
can happen anywhere outside php as well, be a shell script, ftp/ssh, etc.

------------------------------------------------------------------------
[2013-10-01 04:21:25] paj...@php.net

Should have been:

... and will drastically affect performance without actually solving the 
problem....

------------------------------------------------------------------------
[2013-10-01 04:15:57] paj...@php.net

I am not sure it is actually a PHP problem. To create the right locking 
mechanism 
to avoid such issue to happen between (almost) simultaneous requests is the 
application developer job, not the core.

Adding such tests should be done in almost all file creation operations (and 
some 
other) and will drastically performance without actually solving the problem.

------------------------------------------------------------------------
[2013-09-30 10:39:45] me at vlastv dot ru

Problem still exists in PHP 5.4.1.

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    https://bugs.php.net/bug.php?id=35326


-- 
Edit this bug report at https://bugs.php.net/bug.php?id=35326&edit=1

Reply via email to