Sha256: 083c8b3349cd8f92def5d1789e4ce3ebe61b092344d544e477b1a3fc6afcde84

Contents?: true

Size: 1.43 KB

Versions: 27

Compression:

Stored size: 1.43 KB

Contents

# encoding: utf-8

require 'one_apm/collector/sampler'

module OneApm
  module Collector
    module Samplers
      class CpuSampler < OneApm::Collector::Sampler
        attr_reader :last_time

        named :cpu

        def initialize
          @processor_count = OneApm::Support::SystemInfo.num_logical_processors
          poll
        end

        def self.supported_on_this_platform?
          # Process.times on JRuby < 1.7.0 reports wall clock elapsed time, not actual cpu time used
          defined?(JRuby) ? (JRUBY_VERSION >= '1.7.0') : true
        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

            if systemtime >= 0
              OneApm::Manager.record_metric("CPU/System Time", systemtime)
              OneApm::Manager.record_metric("CPU/System/Utilization", systemtime / (elapsed * @processor_count))
            end
            if usertime >= 0
              OneApm::Manager.record_metric("CPU/User Time", usertime)
              OneApm::Manager.record_metric("CPU/User/Utilization", usertime / (elapsed * @processor_count))
            end
          end
          @last_utime = t.utime
          @last_stime = t.stime
          @last_time = now
        end
      end
    end
  end
end

Version data entries

27 entries across 27 versions & 1 rubygems

Version Path
oneapm_rpm-1.3.3 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.3.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.2 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.2.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.1.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.0 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.3.0.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.9 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.9.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.8 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.8.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.7 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.7.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.6 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.6.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.5 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.5.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.4 lib/one_apm/collector/samplers/cpu_sampler.rb
oneapm_rpm-1.2.4.rc1 lib/one_apm/collector/samplers/cpu_sampler.rb