#!/usr/bin/python from xen.xm.main import SERVER_LEGACY_XMLRPC, SERVER_XEN_API, parseServer, parseAuthentication from xen.xend import sxp import atexit import sys serverType, serverURI = parseServer() if serverType != SERVER_LEGACY_XMLRPC: print >>sys.stderr, "xen_cpu is untested with this Xen server type" sys.exit(1) if serverType == SERVER_XEN_API: from xen.xm import XenAPI server = XenAPI.Session(serverURI) username, password = parseAuthentication() server.login_with_password(username, password) def logout(): try: server.xenapi.session.logout() except: pass atexit.register(logout) else: from xen.util.xmlrpcclient import ServerProxy server = ServerProxy(serverURI) if len(sys.argv) > 1: cmd = sys.argv[1] else: cmd = None def getDomains(): ret = {} if serverType == SERVER_XEN_API: domains = server.xenapi.VM.get_all_records() metrics = server.xenapi.VM_metrics.get_all_records() for d in domains.values(): ret['uuid_'+d['uuid'].replace('-', '_')] = {'name': d['name_label'], 'cpu_time': sum(metrics[d['metrics']]['VCPUs_utilisation'].values()), 'domid': d['domid'], 'uuid': d['uuid'], # No equivalent } return ret else: domains = server.xend.domains_with_state(True, 'all', True) for d in domains: data = {'name': sxp.child_value(d, 'name', 'UNKNOWN'), 'cpu_time': sxp.child_value(d, 'cpu_time', 0.0), 'domid': sxp.child_value(d, 'domid', -1), 'uuid': sxp.child_value(d, 'uuid', 'NONE'), } try: sched = server.xend.domain.sched_credit_get(data['name']) data['sched-credit'] = sched except: data['sched-credit'] = None ret['uuid_'+sxp.child_value(d, 'uuid', 'NONE').replace('-', '_')] = data return ret if cmd == 'config': print """ graph_title Xen domain CPU usage graph_args --base 1000 -r --lower-limit 0 --upper-limit 800 graph_vlabel % graph_scale no graph_info This graph shows how CPU time is spent by Xen domains. graph_category system graph_period second""" domains = getDomains() for d in sorted(domains): name = domains[d]['name'] if name[0:2] == 'd_': name = 'db domid %d' % domains[d]['domid'] print "%s.label %s" % (d, name) if domains[d]['domid'] == 0: print "%s.draw AREA" % d else: print "%s.draw STACK" % d print "%s.max 19200000000" % d # 64x 100% CPU usage print "%s.min 0" % d print "%s.type DERIVE" % d if domains[d].get('sched-credit'): print "%s.info uuid %s CPU weight %d cap %d%%" % (d, domains[d]['uuid'], domains[d]['sched-credit']['weight'], domains[d]['sched-credit']['cap']) else: print "%s.info uuid %s" % (d, domains[d]['uuid']) print "%s.cdef %s,10000,/" % (d, d) sys.exit(0) domains = getDomains() for d in sorted(domains): print "%s.value %s" % (d, long(domains[d]['cpu_time']*1000000))