forked from reubenur-rahman/vmware-pyvmomi-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cold_migration_without_vmotion.py
124 lines (106 loc) · 3.98 KB
/
cold_migration_without_vmotion.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
'''
Copyright 2013-2014 Reubenur Rahman
All Rights Reserved
@author: [email protected]
'''
import atexit
import argparse
import sys
import time
from pyVmomi import vim, vmodl
from pyVim import connect
from pyVim.connect import Disconnect
inputs = {'vcenter_ip': '15.14.10.11',
'vcenter_password': 'Passw0rd',
'vcenter_user': 'Administrator',
'vm_name' : 'ubuntu12',
'target_host': '15.14.10.12',
'datacenter':'My_Datacenter'
}
def get_obj(content, vimtype, name):
"""
Get the vsphere object associated with a given text name
"""
obj = None
container = content.viewManager.CreateContainerView(content.rootFolder, vimtype, True)
for c in container.view:
if c.name == name:
obj = c
break
return obj
def wait_for_task(task, actionName='job', hideResult=False):
"""
Waits and provides updates on a vSphere task
"""
while task.info.state == vim.TaskInfo.State.running:
time.sleep(2)
if task.info.state == vim.TaskInfo.State.success:
if task.info.result is not None and not hideResult:
out = '%s completed successfully, result: %s' % (actionName, task.info.result)
print out
else:
out = '%s completed successfully.' % actionName
print out
else:
out = '%s did not complete successfully: %s' % (actionName, task.info.error)
raise task.info.error
print out
return task.info.result
def main():
#args = GetArgs()
try:
si = None
try:
print "Trying to connect to VCENTER SERVER . . ."
si = connect.Connect(inputs['vcenter_ip'], 443, inputs['vcenter_user'], inputs['vcenter_password'])
except IOError, e:
pass
atexit.register(Disconnect, si)
print "Connected to VCENTER SERVER !"
content = si.RetrieveContent()
datacenter = get_obj(content, [vim.Datacenter], inputs['datacenter'])
# get the folder where VMs are kept for this datacenter
vmFolder = datacenter.vmFolder
#vm_name = args.vm
vm_name = inputs['vm_name']
vm = get_obj(content, [vim.VirtualMachine], vm_name)
if vm.runtime.powerState != 'poweredOff':
print "WARNING:: Power off your VM before cold migration"
sys.exit()
target_host = get_obj(content, [vim.HostSystem], inputs['target_host'])
relocate_spec = vim.vm.RelocateSpec()
for datastore in target_host.datastore:
#Store the OVS vApp VM in local datastore of each host
if datastore.summary.type == 'VMFS':
print " Moving the VM in %s" % datastore.name
relocate_spec.datastore = datastore
break
relocate_spec.host = target_host
relocate_spec.pool = vm.resourcePool
cloneSpec = vim.vm.CloneSpec(powerOn=False, template=False, location=relocate_spec)
print "Moving the VM "
task = vm.Clone(name='temp', folder=vmFolder, spec=cloneSpec)
job_status = wait_for_task(task, si)
if job_status:
vmconf = vim.vm.ConfigSpec()
vmconf.name = vm.config.name
vmconf.uuid = vm.config.uuid
print "Destroying the source VM"
task = vm.Destroy()
wait_for_task(task, si)
print "Configuring the VM with old name and uuid"
new_vm = get_obj(content, [vim.VirtualMachine], 'temp')
task = new_vm.ReconfigVM_Task(vmconf)
wait_for_task(task, si)
print "Successfully cold migrated"
else:
print "Error while cold migration"
except vmodl.MethodFault, e:
print "Caught vmodl fault: %s" % e.msg
return 1
except Exception, e:
print "Caught exception: %s" % str(e)
return 1
# Start program
if __name__ == "__main__":
main()