Sha256: 1167933494a38e823cf11da97767f5d444d338ca465d9ca48be0591f9bf48e95

Contents?: true

Size: 1.14 KB

Versions: 96

Compression:

Stored size: 1.14 KB

Contents

# Copyright (c) 2015 Sqreen. All Rights Reserved.
# Please refer to our terms for more information: https://www.sqreen.io/terms.html

require 'sqreen/performance_notifications'

module Sqreen
  module PerformanceNotifications
    # Log performances in sqreen metrics_store
    class Metrics
      @subid = nil
      @facility = nil
      class << self
        EVENT_CAT = 'sqreen_time'.freeze
        def log(event, start, finish, _meta)
          evt = [EVENT_CAT, event, (finish - start) * 1000, finish]
          Sqreen.observations_queue.push(evt)
        end

        def enable(metrics_engine, period = 60)
          return unless @subid.nil?
          metrics_engine.create_metric('name' => EVENT_CAT,
                                       'period' => period,
                                       'kind' => 'Average')
          @subid = Sqreen::PerformanceNotifications.subscribe(nil,
                                                              &method(:log))
        end

        def disable
          return if @subid.nil?
          Sqreen::PerformanceNotifications.unsubscribe(@subid)
          @subid = nil
        end
      end
    end
  end
end

Version data entries

96 entries across 96 versions & 2 rubygems

Version Path
sqreen-1.10.5-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.5 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.5 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.4-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.4 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.4 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.3-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.3 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.3 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.2-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.2 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.2 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.1-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.1 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.1 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.0-java lib/sqreen/performance_notifications/metrics.rb
sqreen-alt-1.10.0 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.10.0 lib/sqreen/performance_notifications/metrics.rb
sqreen-1.9.2-java lib/sqreen/performance_notifications/metrics.rb
sqreen-1.9.2 lib/sqreen/performance_notifications/metrics.rb