source: trunk/packages/sipb-xen-remote-server/files/usr/sbin/sipb-xen-remote-create @ 1086

Last change on this file since 1086 was 816, checked in by y_z, 16 years ago
  • use invirt.config to get hostnames
  • refactoring: extracted bcast() function into invirt.remote package
  • fixed os.rename import bug
  • using correct default paths in invirt-getconf
  • Property svn:executable set to *
File size: 1.5 KB
RevLine 
[658]1#!/usr/bin/python
[816]2
[658]3"""
4Picks a host to "create" (boot) a VM on, and does so.
5
[665]6Current load-balancing algorithm: wherever there's more free RAM.
[658]7
8TODO: use a lock to avoid creating the same VM twice in a race
9"""
10
[816]11from invirt.remote import bcast
[658]12from subprocess import PIPE, Popen, call
13import sys
14import yaml
15
16def choose_host():
17    # Query each of the hosts.
18    # XXX will the output of 'xm info' always be parseable YAML?
[816]19    results = bcast('info')
20    return max((int(o['free_memory']), s) for (s, o) in results)[1]
[658]21
22def main(argv):
23    if len(argv) < 2:
[816]24        print >> sys.stderr, "usage: sipb-xen-remote-create <machine> [<other args...>]"
[658]25        return 2
26    machine_name = argv[1]
27    args = argv[2:]
28
29    p = Popen(['/usr/sbin/sipb-xen-remote-proxy-web', 'listvms'], stdout=PIPE)
30    output = p.communicate()[0]
31    if p.returncode != 0:
32        raise RuntimeError("Command '%s' returned non-zero exit status %d"
33                           % ('sipb-xen-remote-proxy-web', p.returncode)) 
34    vms = yaml.load(output, yaml.CSafeLoader)
35
36    if machine_name in vms:
37        host = vms[machine_name]['host']
[816]38        print >> sys.stderr, ("machine '%s' is already running on host %s"
39                              % (machine_name, host))
[658]40        return 1
41
42    host = choose_host()
43    print 'Creating on host %s...' % host
[664]44    sys.stdout.flush()
[658]45    return call(['remctl', host, 'remote', 'control',
46                 machine_name, 'create'] + args)
47
48if __name__ == '__main__':
49    sys.exit(main(sys.argv))
50
51# vim:et:sw=4:ts=4
Note: See TracBrowser for help on using the repository browser.