qvm-backup-restore: support for --skip-conflicting option
This commit is contained in:
parent
751e0b380a
commit
a5c4a1626e
@ -113,6 +113,9 @@ def main():
|
|||||||
parser.add_option ("--ignore-missing", action="store_true", dest="ignore_missing", default=False,
|
parser.add_option ("--ignore-missing", action="store_true", dest="ignore_missing", default=False,
|
||||||
help="Ignore missing templates or netvms, restore VMs anyway")
|
help="Ignore missing templates or netvms, restore VMs anyway")
|
||||||
|
|
||||||
|
parser.add_option ("--skip-conflicting", action="store_true", dest="skip_conflicting", default=False,
|
||||||
|
help="Do not restore VMs that are already present on the host")
|
||||||
|
|
||||||
(options, args) = parser.parse_args ()
|
(options, args) = parser.parse_args ()
|
||||||
|
|
||||||
if (len (args) != 1):
|
if (len (args) != 1):
|
||||||
@ -186,7 +189,7 @@ def main():
|
|||||||
if host_collection.get_vm_by_name (vm.name) is not None:
|
if host_collection.get_vm_by_name (vm.name) is not None:
|
||||||
s += " <-- A VM with the same name already exists on the host!"
|
s += " <-- A VM with the same name already exists on the host!"
|
||||||
there_are_conflicting_vms = True
|
there_are_conflicting_vms = True
|
||||||
good_to_go = False
|
good_to_go = False # Do not overwrite VMs on the host!
|
||||||
|
|
||||||
if vm.is_appvm():
|
if vm.is_appvm():
|
||||||
templatevm_name = vm.template_vm.name
|
templatevm_name = vm.template_vm.name
|
||||||
@ -224,9 +227,11 @@ def main():
|
|||||||
|
|
||||||
if there_are_conflicting_vms:
|
if there_are_conflicting_vms:
|
||||||
print "*** There VMs with conflicting names on the host! ***"
|
print "*** There VMs with conflicting names on the host! ***"
|
||||||
|
if options.skip_conflicting:
|
||||||
|
print "Those VMs will not be restored, the host VMs will not be overwritten!"
|
||||||
|
else:
|
||||||
print "Remove VMs with conflicting names from the host before proceeding."
|
print "Remove VMs with conflicting names from the host before proceeding."
|
||||||
print "You can use 'qvm-remove <vmname>' command for this."
|
print "... or use --skip-conflicting to restore only those VMs that do not exist on the host."
|
||||||
print "Be careful! Think twice before typing qvm-remove!!!"
|
|
||||||
exit (1)
|
exit (1)
|
||||||
|
|
||||||
print "The above VMs will be copied and added to your system."
|
print "The above VMs will be copied and added to your system."
|
||||||
@ -241,7 +246,7 @@ def main():
|
|||||||
elif options.skip_broken:
|
elif options.skip_broken:
|
||||||
print "... VMs that depend on it will not be restored (--skip-broken used)"
|
print "... VMs that depend on it will not be restored (--skip-broken used)"
|
||||||
elif options.ignore_missing:
|
elif options.ignore_missing:
|
||||||
print "... VMs that depend on it be restored anyway (--ignore-missing used)"
|
print "... VMs that depend on it will be restored anyway (--ignore-missing used)"
|
||||||
else:
|
else:
|
||||||
print "INTERNAL ERROR?!"
|
print "INTERNAL ERROR?!"
|
||||||
exit (1)
|
exit (1)
|
||||||
|
Loading…
Reference in New Issue
Block a user