Sha256: da2b68aec9981279299136ddec896d9f5c1ebb0a4e9b58c182f39307e474b9ad
Contents?: true
Size: 1.21 KB
Versions: 29
Compression:
Stored size: 1.21 KB
Contents
# typed: true # Copyright (c) 2015 Sqreen. All Rights Reserved. # Please refer to our terms for more information: https://www.sqreen.com/terms.html require 'sqreen/performance_notifications' require 'sqreen/performance_notifications/log' require 'sqreen/runner' module Sqreen module PerformanceNotifications # Log performances in sqreen metrics_store class Metrics < Log @subid = nil @facility = nil class << self EVENT_CAT = 'sqreen_time'.freeze def log(rule, cb, start, finish, _meta) event = event_name(rule, cb) evt = [EVENT_CAT, event, (finish - start) * 1000, Time.now.utc] 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(&method(:log)) end def disable return if @subid.nil? Sqreen::PerformanceNotifications.unsubscribe(@subid) @subid = nil end end end end end
Version data entries
29 entries across 29 versions & 1 rubygems