2 # Migrates the machine passed as arguments from the dev cluster.
3 # To be run on the prod cluster.
5 from invirt import remctl as r
6 from lib import database
10 dev_db_uri = 'postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen'
11 database.connect(dev_db_uri)
12 dev_sess = database.session
15 prod_sess = database.session
18 def take_data(machine_name):
20 machine = dev_sess.query(database.Machine).filter_by(name=machine_name).one()
22 # Clean out the ACL just so we don't have to think about it
24 dev_sess.update(machine)
27 print ' name: %s' % machine.name
28 print ' description: %s' % machine.description
29 print ' cpus: %s' % machine.cpus
30 print ' memory: %s' % machine.memory
31 print ' owner: %s' % machine.owner
32 print ' contact: %s' % machine.contact
33 print ' administrator: %s' % machine.administrator
34 print ' uuid: %s' % machine.uuid
35 print ' type: %s' % machine.type.type_id
36 print ' autorestart: %s' % machine.autorestart
37 print ' adminable: %s' % machine.adminable
39 for disk in machine.disks:
40 print ' - %s (%s)' % (disk.guest_device_name, disk.size)
42 for nic in machine.nics:
43 print ' - %s, %s, %s' % (nic.mac_addr, nic.ip, nic.hostname)
44 print '==============================================='
49 for r in disks + nics + [machine]:
54 for r in disks + nics + [machine]:
61 def restore_data(machine, session):
62 # The machine's type is still the one attached to the dev database;
64 machine.type = session.query(database.Type).filter_by(type_id=machine.type.type_id).one()
69 def migrate_vm(machine_name):
70 # Power off the VM on dev
72 # This has to be done first, because once the machine is deleted
73 # from the database, we can't remctl for it anymore
74 out, err = r.remctl('xvm-remote.mit.edu', 'control', machine_name, 'destroy', err=True)
77 machine = take_data(machine_name)
80 ## copy disk image... copy, copy...
81 for disk in machine.disks:
82 lvname='d_%s_%s' % (machine.name, disk.guest_device_name)
84 if 0 != subprocess.call(['lvcreate', '-L%sM' % str(disk.size), '-n', lvname, 'xenvg']):
87 ssh = subprocess.Popen(['ssh', '-o', 'GSSAPIDelegateCredentials=no',
88 'torchwood-institute.mit.edu',
89 'dd', 'if=/dev/xenvg/%s' % lvname, 'bs=1M'],
90 stdout=subprocess.PIPE)
91 dd = subprocess.Popen(['dd', 'of=/dev/xenvg/%s' % lvname, 'bs=1M'],
99 restore_data(machine, dev_sess)
101 print '==============================================='
102 print 'ERROR: VM %s failed to migrate' % machine.name
103 print '==============================================='
105 restore_data(machine, prod_sess)
107 if __name__ == '__main__':
108 for vm in sys.argv[1:]:
109 print '==============================================='
110 print 'Migrating %s' % vm
111 print '==============================================='
112 migrate_vm(vm.strip())