X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/xvm-munin-config.git/blobdiff_plain/0e3a37c0643ef2fcb17883b78881f63ca16ea459..08d0fec60bf11b887c70fc872d1733c1c10a9e06:/host/usr/share/xvm-munin-host-config/plugins/xen_cpu diff --git a/host/usr/share/xvm-munin-host-config/plugins/xen_cpu b/host/usr/share/xvm-munin-host-config/plugins/xen_cpu index ecb68be..2efffe4 100755 --- a/host/usr/share/xvm-munin-host-config/plugins/xen_cpu +++ b/host/usr/share/xvm-munin-host-config/plugins/xen_cpu @@ -1,10 +1,16 @@ #!/usr/bin/python -from xen.xm.main import SERVER_LEGACY_XMLRPC, SERVER_XEN_API, parseServer +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) @@ -20,8 +26,6 @@ else: from xen.util.xmlrpcclient import ServerProxy server = ServerProxy(serverURI) -import sys - if len(sys.argv) > 1: cmd = sys.argv[1] else: @@ -30,23 +34,30 @@ else: def getDomains(): ret = {} if serverType == SERVER_XEN_API: - domains = server.xenapu.VM.get_all_records() + domains = server.xenapi.VM.get_all_records() metrics = server.xenapi.VM_metrics.get_all_records() for d in domains.values(): ret[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: - ret[sxp.child_value(d, 'uuid', 'NONE').replace('-', '_')] = {'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'), - } + 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[sxp.child_value(d, 'uuid', 'NONE').replace('-', '_')] = data return ret if cmd == 'config': @@ -62,16 +73,19 @@ graph_period second""" for d in sorted(domains): name = domains[d]['name'] if name[0:2] == 'd_': - name = 'user domain' + 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 5000" % d + print "%s.max 19200000000" % d # 64x 100% CPU usage print "%s.min 0" % d print "%s.type DERIVE" % d - print "%s.info %s" % (d, domains[d]['uuid']) + 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)