Skip to content

Instantly share code, notes, and snippets.

@AliYmn
Created August 22, 2017 06:41
Show Gist options
  • Save AliYmn/989c4f1f12773b296368b310dc5c424b to your computer and use it in GitHub Desktop.
Save AliYmn/989c4f1f12773b296368b310dc5c424b to your computer and use it in GitHub Desktop.
#!/usr/bin/env python
"""
Written by Lance Hasson
Github: https://github.com/JLHasson
Script to report all available realtime performance metrics from a
virtual machine. Based on a Java example available in the VIM API 6.0
documentationavailable online at:
https://pubs.vmware.com/vsphere-60/index.jsp?topic=%2Fcom.vmware.wssdk.pg.
doc%2FPG_Performance.18.4.html&path=7_1_0_1_15_2_4
Requirements:
VM tools must be installed on all virtual machines.
"""
from pyVmomi import vim
from tools import cli
from pyVim.connect import SmartConnectNoSSL, Disconnect
import atexit
import getpass
def main():
args = cli.get_args()
# Connect to the host without SSL signing
try:
si = SmartConnectNoSSL(
host=args.host,
user=args.user,
pwd=args.password,
port=int(args.port))
atexit.register(Disconnect, si)
except IOError as e:
pass
if not si:
raise SystemExit("Unable to connect to host with supplied info.")
content = si.RetrieveContent()
perfManager = content.perfManager
# create a mapping from performance stats to their counterIDs
# counterInfo: [performance stat => counterId]
# performance stat example: cpu.usagemhz.LATEST
# counterId example: 6
counterInfo = {}
for c in perfManager.perfCounter:
prefix = c.groupInfo.key
fullName = c.groupInfo.key + "." + c.nameInfo.key + "." + c.rollupType
counterInfo[fullName] = c.key
# create a list of vim.VirtualMachine objects so
# that we can query them for statistics
container = content.rootFolder
viewType = [vim.VirtualMachine]
recursive = True
containerView = content.viewManager.CreateContainerView(container,
viewType,
recursive)
children = containerView.view
# Loop through all the VMs
for child in children:
# Get all available metric IDs for this VM
counterIDs = [m.counterId for m in
perfManager.QueryAvailablePerfMetric(entity=child)]
# Using the IDs form a list of MetricId
# objects for building the Query Spec
metricIDs = [vim.PerformanceManager.MetricId(counterId=c,
instance="*")
for c in counterIDs]
# Build the specification to be used
# for querying the performance manager
spec = vim.PerformanceManager.QuerySpec(maxSample=1,
entity=child,
metricId=metricIDs)
# Query the performance manager
# based on the metrics created above
result = perfManager.QueryStats(querySpec=[spec])
# Loop through the results and print the output
output = ""
for r in result:
output += "name: " + child.summary.config.name + "\n"
for val in result[0].value:
output += counterInfo.keys()[
counterInfo.values().index(val.id.counterId)]
output += ": " + str(val.value[0]) + "\n"
output += "\n"
print(output)
if __name__ == "__main__":
main()
@AliYmn
Copy link
Author

AliYmn commented Aug 22, 2017

name: WindowsKlon1
cpu.usage.average: 19
cpu.usagemhz.average: 26
cpu.ready.summation: 1005
mem.usage.average: 3297
mem.swapinRate.average: 0
mem.swapoutRate.average: 0
mem.vmmemctl.average: 0
mem.consumed.average: 1133511
mem.overhead.average: 49058
disk.usage.average: 304
disk.maxTotalLatency.latest: 0
net.usage.average: 0
sys.uptime.latest: 2895
disk.used.latest: 15958240
disk.used.latest: 0
disk.used.latest: 11572224
disk.used.latest: 191712
disk.used.latest: 4194304
disk.used.latest: 15958240
disk.used.latest: 0
disk.used.latest: 11572224
disk.used.latest: 191712
disk.used.latest: 4194304
disk.used.latest: 15958240
disk.used.latest: 0
disk.used.latest: 11572224
disk.used.latest: 191712
disk.used.latest: 4194304
disk.used.latest: 15958240
disk.used.latest: 0
disk.used.latest: 11572224
disk.used.latest: 191712
disk.used.latest: 4194304
disk.used.latest: 15958240
disk.used.latest: 0
disk.used.latest: 11572224
disk.used.latest: 191712
disk.used.latest: 4194304
disk.provisioned.latest: 46329057
disk.unshared.latest: 11572224

name: WindowsKlon26
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon24
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon23
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon21
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon19
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon15
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon25
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon14
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon13
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.provisioned.latest: 25357325
disk.unshared.latest: 9265152

name: WindowsKlon18
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.used.latest: 13650956
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 191500
disk.used.latest: 4194304
disk.provisioned.latest: 25357325
disk.unshared.latest: 9265152

name: WindowsKlon10
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon9
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon8
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon7
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon16
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon5
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon11
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon6
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon22
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon20
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon3
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon17
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon4
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 4194304
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 4194304
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 4194304
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 4194304
disk.used.latest: 9265164
disk.used.latest: 0
disk.used.latest: 9265152
disk.used.latest: 12
disk.used.latest: 4194304
disk.provisioned.latest: 25356497
disk.unshared.latest: 9265152

name: WindowsKlon2
cpu.usage.average: 298
cpu.usagemhz.average: 406
cpu.ready.summation: 99
mem.usage.average: 7788
mem.swapinRate.average: 0
mem.swapoutRate.average: 0
mem.vmmemctl.average: 0
mem.consumed.average: 438531
mem.overhead.average: 34533
disk.usage.average: 4249
disk.maxTotalLatency.latest: 6
net.usage.average: 0
sys.uptime.latest: 111
disk.used.latest: 9146949
disk.used.latest: 0
disk.used.latest: 9146368
disk.used.latest: 581
disk.used.latest: 4194304
disk.used.latest: 9146949
disk.used.latest: 0
disk.used.latest: 9146368
disk.used.latest: 581
disk.used.latest: 4194304
disk.used.latest: 9146949
disk.used.latest: 0
disk.used.latest: 9146368
disk.used.latest: 581
disk.used.latest: 4194304
disk.used.latest: 9146949
disk.used.latest: 0
disk.used.latest: 9146368
disk.used.latest: 581
disk.used.latest: 4194304
disk.used.latest: 9146949
disk.used.latest: 0
disk.used.latest: 9146368
disk.used.latest: 581
disk.used.latest: 4194304
disk.provisioned.latest: 25357066
disk.unshared.latest: 9146368

name: Windows vcenter
cpu.usage.average: 37
cpu.usagemhz.average: 51
cpu.ready.summation: 12877
mem.usage.average: 389
mem.swapinRate.average: 0
mem.swapoutRate.average: 0
mem.vmmemctl.average: 0
mem.consumed.average: 4194304
mem.overhead.average: 52140
disk.usage.average: 171
disk.maxTotalLatency.latest: 0
net.usage.average: 186
sys.uptime.latest: 15871
disk.used.latest: 11690560
disk.used.latest: 0
disk.used.latest: 11689984
disk.used.latest: 576
disk.used.latest: 4194304
disk.used.latest: 11690560
disk.used.latest: 0
disk.used.latest: 11689984
disk.used.latest: 576
disk.used.latest: 4194304
disk.used.latest: 11690560
disk.used.latest: 0
disk.used.latest: 11689984
disk.used.latest: 576
disk.used.latest: 4194304
disk.used.latest: 11690560
disk.used.latest: 0
disk.used.latest: 11689984
disk.used.latest: 576
disk.used.latest: 4194304
disk.used.latest: 11690560
disk.used.latest: 0
disk.used.latest: 11689984
disk.used.latest: 576
disk.used.latest: 4194304
disk.provisioned.latest: 46328581
disk.unshared.latest: 11689984

name: vcenter 6.0 192.168.1.95
cpu.usage.average: 449
cpu.usagemhz.average: 612
cpu.ready.summation: 52819
mem.usage.average: 1556
mem.swapinRate.average: 0
mem.swapoutRate.average: 0
mem.vmmemctl.average: 0
mem.consumed.average: 14825253
mem.overhead.average: 74674
disk.usage.average: 594
disk.maxTotalLatency.latest: 0
net.usage.average: 19
sys.uptime.latest: 39317
disk.used.latest: 28860625
disk.used.latest: 0
disk.used.latest: 11913216
disk.used.latest: 170193
disk.used.latest: 16777216
disk.used.latest: 28860625
disk.used.latest: 0
disk.used.latest: 11913216
disk.used.latest: 170193
disk.used.latest: 16777216
disk.used.latest: 28860625
disk.used.latest: 0
disk.used.latest: 11913216
disk.used.latest: 170193
disk.used.latest: 16777216
disk.used.latest: 28860625
disk.used.latest: 0
disk.used.latest: 11913216
disk.used.latest: 170193
disk.used.latest: 16777216
disk.used.latest: 28860625
disk.used.latest: 0
disk.used.latest: 11913216
disk.used.latest: 170193
disk.used.latest: 16777216
disk.provisioned.latest: 184076503
disk.unshared.latest: 11913216

name: VMware vCenter Server Appliance 6.5
cpu.usage.average: 146
cpu.usagemhz.average: 199
cpu.ready.summation: 19364
mem.usage.average: 898
mem.swapinRate.average: 0
mem.swapoutRate.average: 0
mem.vmmemctl.average: 0
mem.consumed.average: 12037456
mem.overhead.average: 70211
disk.usage.average: 35
disk.maxTotalLatency.latest: 1
net.usage.average: 1
sys.uptime.latest: 24784
disk.used.latest: 18451292
disk.used.latest: 0
disk.used.latest: 18449408
disk.used.latest: 1884
disk.used.latest: 16777216
disk.used.latest: 18451292
disk.used.latest: 0
disk.used.latest: 18449408
disk.used.latest: 1884
disk.used.latest: 16777216
disk.used.latest: 18451292
disk.used.latest: 0
disk.used.latest: 18449408
disk.used.latest: 1884
disk.used.latest: 16777216
disk.used.latest: 18451292
disk.used.latest: 0
disk.used.latest: 18449408
disk.used.latest: 1884
disk.used.latest: 16777216
disk.used.latest: 18451292
disk.used.latest: 0
disk.used.latest: 18449408
disk.used.latest: 1884
disk.used.latest: 16777216
disk.provisioned.latest: 299805223
disk.unshared.latest: 18449408

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment