X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-remote.git/blobdiff_plain/b4dbbb60d164d05d90c474306050482e92efc36e..9018296f02a04ee42e6360586957992d3a737fd0:/files/usr/sbin/sipb-xen-listvms diff --git a/files/usr/sbin/sipb-xen-listvms b/files/usr/sbin/sipb-xen-listvms index 7f6cb39..a38c9ae 100755 --- a/files/usr/sbin/sipb-xen-listvms +++ b/files/usr/sbin/sipb-xen-listvms @@ -3,32 +3,35 @@ import sys import time sys.path.insert(0, '/usr/lib/xen-3.1-1/lib/python') -from xen.lowlevel.xs import xs +from xen.xend.xenstore import xstransact -trans = xs() +xst = xstransact.xstransact() def live_vms(): - domids = set(trans.ls('', '/local/domain')) + domids = set(xst.List('/local/domain')) domids.discard('0') vms = dict() for domid in domids: - name, data = get_dom(int(domid)) + try: + name, data = get_dom(int(domid)) + except 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 = xst.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'] = xst.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'] = xst.Read('/local/domain/%d/vm' % domid) + data['start_time'] = float(xst.Read('%s/start_time' % data['vm'])) data['uptime'] = time.time()-data['start_time'] return name, data