You are not logged in.
Hi,
I update my custom remote repository by mounting it via SSHFS, copying the new packages there, cd there, and:
`repo-add repo.db.tar.gz package_1 package_2 ...`
It works fine, but other users do the same, to the same repository, possibly simultaneously.
I know that `repo-add` creates a lockfile, supposedly atomically, with:
`set -o noclobber; echo "$$" > "$LOCKFILE"`
So on a local storage that poses no problem. But how about a remote mount? Is there a theoretical danger of a corrupt database?
P.S. I mount the SSHFS with `-o cache=no`.
Last edited by blochl (2019-04-13 15:42:10)
Offline

LOCKFILE is the repo db file path+name with .lck appended. So this should be safe.
Offline
LOCKFILE is the repo db file path+name with .lck appended. So this should be safe.
But on a remote mount, there is no guarantee that while one user started to write the .lck, the other user will see it, if the process is started simultaneously. Or is there?
In other words, is there a guarantee for this operation to be atomic?
Offline

If you can't rely on a file being seen on the filesystem, then no it is not.
Offline
If you can't rely on a file being seen on the filesystem, then no it is not.
Well, I guess so. Moved the repo-add run to the server side now. Thanks.
Offline