Sha256: 43df19dbde11d807c21271d71ec73263875dd166b32823a3b58911995058dbb8
Contents?: true
Size: 1.46 KB
Versions: 2
Compression:
Stored size: 1.46 KB
Contents
#! /usr/bin/env ruby # # metrics-windows-cpu-load.rb # # DESCRIPTION: # This is metrics which outputs the CPU load in Graphite acceptable format. # To get the cpu stats for Windows Server to send over to Graphite. # It basically uses the typeperf to get the processor usage at a given particular time. # # OUTPUT: # metric data # # PLATFORMS: # Windows # # DEPENDENCIES: # gem: sensu-plugin # # USAGE: # # NOTES: # # LICENSE: # Copyright 2013 <jashishtech@gmail.com> # Released under the same terms as Sensu (the MIT license); see LICENSE # for details. # require 'sensu-plugin/metric/cli' require 'socket' # # Cpu metric # class CpuMetric < Sensu::Plugin::Metric::CLI::Graphite option :scheme, description: 'Metric naming scheme, text to prepend to .$parent.$child', long: '--scheme SCHEME', default: Socket.gethostname.to_s def acquire_cpu_load temp_arr = [] timestamp = Time.now.utc.to_i IO.popen('typeperf -sc 1 "processor(_total)\\% processor time" ') { |io| io.each { |line| temp_arr.push(line) } } temp = temp_arr[2].split(',')[1] cpu_metric = temp[1, temp.length - 3].to_f [cpu_metric, timestamp] end def run values = acquire_cpu_load metrics = { cpu: { loadavgsec: values[0] } } metrics.each do |parent, children| children.each do |child, value| output [config[:scheme], parent, child].join('.'), value, values[1] end end ok end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
sensu-plugins-windows-0.0.10 | bin/metrics-windows-cpu-load.rb |
sensu-plugins-windows-0.0.9 | bin/metrics-windows-cpu-load.rb |