Implemented an "in progress" dir for differentials that only gets renamed upon success
This commit is contained in:
parent
fca18717fb
commit
1d3e08e804
26
mikes-backup
26
mikes-backup
@ -35,6 +35,7 @@ class MikesBackup:
|
|||||||
|
|
||||||
CONST_FULL_DIRECTORY_NAME = "Full"
|
CONST_FULL_DIRECTORY_NAME = "Full"
|
||||||
CONST_DIFFERENTIAL_DIRECTORY_NAME = "Differential"
|
CONST_DIFFERENTIAL_DIRECTORY_NAME = "Differential"
|
||||||
|
CONST_DIFFERENTIAL_IN_PROGRESS_DIRECTORY_NAME = "IN-PROGRESS"
|
||||||
|
|
||||||
#
|
#
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
@ -360,8 +361,9 @@ class MikesBackup:
|
|||||||
|
|
||||||
# Get directories
|
# Get directories
|
||||||
link_dest_dir = self.determine_rsync_backup_link_destination_path()
|
link_dest_dir = self.determine_rsync_backup_link_destination_path()
|
||||||
destination_dir = self.make_remote_differential_backup_path()
|
destination_dir_in_progress = self.make_remote_differential_in_progress_backup_path()
|
||||||
self.ensure_destination_directory(destination_dir)
|
destination_dir_final = self.make_remote_differential_backup_path()
|
||||||
|
self.ensure_destination_directory(destination_dir_in_progress)
|
||||||
|
|
||||||
# Add link dest arg?
|
# Add link dest arg?
|
||||||
if link_dest_dir:
|
if link_dest_dir:
|
||||||
@ -372,14 +374,20 @@ class MikesBackup:
|
|||||||
args.append(self.make_rsync_source_directory_part())
|
args.append(self.make_rsync_source_directory_part())
|
||||||
|
|
||||||
# Append remote destination directory
|
# Append remote destination directory
|
||||||
args.append(self.make_rsync_remote_destination_part(destination_dir))
|
args.append(self.make_rsync_remote_destination_part(destination_dir_in_progress))
|
||||||
|
|
||||||
# print("Args", str(args))
|
|
||||||
self.log("Link destination dir: " + link_dest_dir)
|
self.log("Link destination dir: " + link_dest_dir)
|
||||||
self.log("Destination dir: " + destination_dir)
|
self.log("Destination dir: " + destination_dir_in_progress)
|
||||||
|
|
||||||
self.execute_rsync(args)
|
self.execute_rsync(args)
|
||||||
|
|
||||||
|
self.log("Rsync seems to have finished successfully")
|
||||||
|
self.log("Renaming temporary directory")
|
||||||
|
self.log("Old: " + destination_dir_in_progress)
|
||||||
|
self.log("New: " + destination_dir_final)
|
||||||
|
os.rename(destination_dir_in_progress, destination_dir_final)
|
||||||
|
self.log("Rename was successful")
|
||||||
|
|
||||||
#
|
#
|
||||||
def make_log_directory_path(self):
|
def make_log_directory_path(self):
|
||||||
|
|
||||||
@ -421,6 +429,13 @@ class MikesBackup:
|
|||||||
|
|
||||||
return os.path.join(self.__destination_dir_base, self.CONST_DIFFERENTIAL_DIRECTORY_NAME)
|
return os.path.join(self.__destination_dir_base, self.CONST_DIFFERENTIAL_DIRECTORY_NAME)
|
||||||
|
|
||||||
|
#
|
||||||
|
def make_remote_differential_in_progress_backup_path(self):
|
||||||
|
|
||||||
|
diff_path_base = self.make_remote_differential_backup_path_base()
|
||||||
|
|
||||||
|
return os.path.join(diff_path_base, self.CONST_DIFFERENTIAL_IN_PROGRESS_DIRECTORY_NAME)
|
||||||
|
|
||||||
#
|
#
|
||||||
def make_remote_differential_backup_path(self):
|
def make_remote_differential_backup_path(self):
|
||||||
|
|
||||||
@ -507,7 +522,6 @@ class MikesBackup:
|
|||||||
if not newest_path:
|
if not newest_path:
|
||||||
self.log("Didn't find a \"Full\" backup on remote")
|
self.log("Didn't find a \"Full\" backup on remote")
|
||||||
|
|
||||||
# TODO: Need to use a temp name for diff directories, so interrupted diffs don't get used
|
|
||||||
# TODO: Allow user to specify whether rsync success is only return 0, or also 23/24 (partial xfers)
|
# TODO: Allow user to specify whether rsync success is only return 0, or also 23/24 (partial xfers)
|
||||||
# Get listing info for all differential directories
|
# Get listing info for all differential directories
|
||||||
differential_path_base = self.make_remote_differential_backup_path_base()
|
differential_path_base = self.make_remote_differential_backup_path_base()
|
||||||
|
Loading…
Reference in New Issue
Block a user