I\'m trying to figure out how if rsyncing files is atomic. I couldn\'t find any confirmation about it. Due to rsync being able to send only deltas, I was under the impressio
No, rsync
does not write files atomically.
During transfer, a hidden temporary file is being created within the same target directory (.[original-filename].[6-random-characters]
) which contains the transferred file in its current state.
If you should happen to lose connection during transfer or rsync
encounters any other problem, causing the connection to be closed, before killing the rsync
process make sure to copy the temporary file in order to keep all the already transferred packages. You can simply rename the temp file (remove the leading "." and the trailing ".xxxxxx" to get the original filename).
Rsync creates a new temporary file which will contain blocks from the local (receiving) copy and whatever blocks it requires from the sending copy. When done the temporary file is moved into place replacing the original.
Full details are here;
http://rsync.samba.org/how-rsync-works.html
There is a perl script that is supposed to add this functionality: http://www.opensource.apple.com/source/rsync/rsync-40/rsync/support/atomic-rsync
The problem is that I tried to test it and it doesn't work. Also there is something strage because from the URL it looks like being something related to rsync 4.0 and the current version of rsync is 2.6.9 !