X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-remote.git/blobdiff_plain/a2e3bd4c859aaa49dcb6ef5dea46e277dc8d65c2..8cd9507f6c1f0bbe98fd52a2a0d2655c0476c860:/files/usr/sbin/sipb-xen-listvms diff --git a/files/usr/sbin/sipb-xen-listvms b/files/usr/sbin/sipb-xen-listvms index 85e9713..79762fa 100755 --- a/files/usr/sbin/sipb-xen-listvms +++ b/files/usr/sbin/sipb-xen-listvms @@ -3,12 +3,12 @@ import sys import time sys.path.insert(0, '/usr/lib/xen-3.1-1/lib/python') -from xen.lowlevel.xs import xs +from xen.lowlevel import xs -trans = xs() +xsc = xs.xs() def live_vms(): - domids = set(trans.ls('', '/local/domain')) + domids = set(xsc.ls('', '/local/domain')) domids.discard('0') vms = dict() @@ -16,22 +16,22 @@ def live_vms(): for domid in domids: try: name, data = get_dom(int(domid)) - except ValueError: - pass # went down since we started + except (xs.Error, TypeError): + continue # went down since we started if name.startswith('d_'): name = name[2:] vms[name] = data return vms def get_dom(domid): - name = trans.read('', '/local/domain/%d/name' % domid) + name = xsc.read('', '/local/domain/%d/name' % domid) data = dict() data['domid'] = domid # presence of a graphical console - data['console'] = trans.read('', '/local/domain/%d/device/vfb/0/state' % domid) + data['console'] = xsc.read('', '/local/domain/%d/device/vfb/0/state' % domid) # uptime - data['vm'] = trans.read('', '/local/domain/%d/vm' % domid) - data['start_time'] = float(trans.read('', '%s/start_time' % data['vm'])) + data['vm'] = xsc.read('', '/local/domain/%d/vm' % domid) + data['start_time'] = float(xsc.read('', '%s/start_time' % data['vm'])) data['uptime'] = time.time()-data['start_time'] return name, data