made copy atomic by creating tmp file in dest location (ensures same partition)
uses pid and epoch to prevent collisions, good enough for most cases Signed-off-by: Brian Coca <briancoca+ansible@gmail.com>
This commit is contained in:
parent
3276c2f0c4
commit
0235be4db5
1 changed files with 6 additions and 1 deletions
7
copy
7
copy
|
@ -20,6 +20,7 @@
|
|||
|
||||
import os
|
||||
import shutil
|
||||
import time
|
||||
|
||||
def main():
|
||||
|
||||
|
@ -64,7 +65,11 @@ def main():
|
|||
if backup:
|
||||
if os.path.exists(dest):
|
||||
backup_file = module.backup_local(dest)
|
||||
shutil.copyfile(src, dest)
|
||||
#TODO:pid + epoch should avoid most collisions, hostname/mac for those using nfs?
|
||||
# might be an issue with exceeding path length
|
||||
dest_tmp = "%s.%s.%s.tmp" % (dest,os.getpid(),time.gmtime)
|
||||
shutil.copyfile(src, dest_tmp)
|
||||
shutil.copyfile(dest_tmp, dest)
|
||||
except shutil.Error:
|
||||
module.fail_json(msg="failed to copy: %s and %s are the same" % (src, dest))
|
||||
except IOError:
|
||||
|
|
Loading…
Add table
Reference in a new issue