Sha256: 80e2097288dd5d4c8c216504d50f38e151fa84fccb000e718229cb8ef561f571

Contents?: true

Size: 1.92 KB

Versions: 5

Compression:

Stored size: 1.92 KB

Contents

# encoding: utf-8

require 'ting_yun/agent'
require 'ting_yun/agent/collector/middle_ware_collector/sampler'
require 'ting_yun/support/system_info'

module TingYun
  module Agent
    module Collector
      class CpuSampler < ::TingYun::Agent::Collector::Sampler
        attr_reader :last_time

        named :cpu

        def initialize
          @last_time = nil
          @processor_count = TingYun::Support::SystemInfo.num_logical_processors
          if @processor_count.nil?
            TingYun::Agent.logger.warn("Failed to determine processor count, assuming 1")
            @processor_count = 1
          end
          poll
        end

        def record_user_util(value)
          TingYun::Agent.record_metric("CPU/NULL/UserUtilization", value)
        end

        def record_system_util(value)
          TingYun::Agent.record_metric("CPU/System/Utilization", value)
        end

        def record_usertime(value)
          TingYun::Agent.record_metric("CPU/NULL/UserTime", value)
        end

        def record_systemtime(value)
          TingYun::Agent.record_metric("CPU/System Time", value)
        end

        def poll
          now = Time.now
          t = Process.times
          if @last_time
            elapsed = now - @last_time
            return if elapsed < 1 # Causing some kind of math underflow

            usertime = t.utime - @last_utime
            # systemtime = t.stime - @last_stime

            # record_systemtime(systemtime) if systemtime >= 0
            record_usertime(usertime) if usertime >= 0

            # Calculate the true utilization by taking cpu times and dividing by
            # elapsed time X processor_count.

            record_user_util(usertime / (elapsed * @processor_count))
            # record_system_util(systemtime / (elapsed * @processor_count))
          end
          @last_utime = t.utime
          @last_stime = t.stime
          @last_time = now
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
tingyun_rpm-1.1.2 lib/ting_yun/agent/collector/middle_ware_collector/cpu_sampler.rb
tingyun_rpm-1.1.1 lib/ting_yun/agent/collector/middle_ware_collector/cpu_sampler.rb
tingyun_rpm-1.1.0 lib/ting_yun/agent/collector/middle_ware_collector/cpu_sampler.rb
tingyun_rpm-1.0.7 lib/ting_yun/agent/collector/middle_ware_collector/cpu_sampler.rb
tingyun_rpm-1.0.6 lib/ting_yun/agent/collector/middle_ware_collector/cpu_sampler.rb