The following script sometimes gives me things like can't remove a/b as it's not empty
ssh -T user@host <<EOF
cd somewhere
rm -rf a/b
EOF
But I log in to the server and execute rm -rf a/b
then I never had the problem.
There are other processes that are generating files to a/b
, is that related?
Anyway, how to make a script that will ensure "a/b" will be deleted?
Best Answer
rmdir(2)
will fail if the directory is not empty. If another process is creating files whilerm(1)
is removing them, it will not know to delete them and consequently when it comes time forrm(1)
to try to delete what it believes should be an empty directory, it will fail with the error you've posted.One way to delete the directory in the face of concurrent file creations in the directory is to rename it:
It's possible that this may not work if the processes creating the files in
a/b
are not doing so by path (open(2)
vs.openat(2)
).I am assuming that the process(es) that creates files in
a/b
will recreate that directory if it does not exist, or will handle failure gracefully if it does not exist. Since you are already trying to delete the directory from under other processes, that seems like a safe assumption.