Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

multithreaded mkdir can fail with multiple backends #354

Open
johnbent opened this issue Jul 17, 2014 · 0 comments
Open

multithreaded mkdir can fail with multiple backends #354

johnbent opened this issue Jul 17, 2014 · 0 comments
Labels

Comments

@johnbent
Copy link
Member

If two separate threads issue a call to plfs_mkdir, it is possible that they both fail with EEXIST and that the directory will not be fully created. What can happen is that each of them will loop through the backends and make that directory on each backend. If there is an error seen then they will exit early with the error and not finish looping through the backends. If the two threads are looping in a different order (unusual but not impossible if for example the order of the backends is different in different plfsrcs or if we are using threads to speedup the mkdir like Grider probably wants us to) then each may exit early and not all backends will be created.

One simple fix is to add EEXIST to the FileOp.ignoreErrno() for the mkdir operation but that then will hide the EEXIST error in situations where it is appropriate to return it. So probably what we need to do is slightly modify FileOp so that it can return a list of errno's instead of a single one and it can return whether any of the errno's in ignoreErrno() where seen. Therefore when this happens, the mkdir FileOp will continue looping through all of the backends but when it is done it will return and say, "Hey, I'm all done but by the way, I did encounter and ignore an EEXIST," and then we can return EEXIST to the caller of plfs_mkdir.

@johnbent johnbent added the bug label Jul 17, 2014
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant