Sha256: 242d72de2b4eb3aa946efe255e0b35af610554a3014b77e66ac256636e2110a9
Contents?: true
Size: 1.35 KB
Versions: 1
Compression:
Stored size: 1.35 KB
Contents
#! /usr/bin/env ruby # frozen_string_literal: false # # metric-windows-processor-queue-length.rb # # DESCRIPTION: # This plugin collects and outputs the Processor Queue Length. # It uses Typeperf to get the processor usage. # # OUTPUT: # metric data # # PLATFORMS: # Windows # # DEPENDENCIES: # gem: sensu-plugin # # USAGE: # # NOTES: # # LICENSE: # Andy Royle <ajroyle@gmail.com> # Released under the same terms as Sensu (the MIT license); see LICENSE for details. # require 'sensu-plugin/metric/cli' require 'socket' 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 "system\\processor queue length" ') { |io| io.each { |line| temp_arr.push(line) } } temp = temp_arr[2].split(',')[1] queue_metric = temp[1, temp.length - 3].to_f [queue_metric, timestamp] end def run values = acquire_cpu_load metrics = { cpu: { queuelength: 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
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
sensu-plugins-windows-3.0.0 | bin/metric-windows-processor-queue-length.rb |