Class: Honeybadger::NotificationSubscriber
- Inherits:
-
Object
- Object
- Honeybadger::NotificationSubscriber
- Includes:
- InstrumentationHelper
- Defined in:
- lib/honeybadger/notification_subscriber.rb
Direct Known Subclasses
ActionControllerCacheSubscriber, ActionControllerSubscriber, ActionMailerSubscriber, ActionViewSubscriber, ActiveJobSubscriber, ActiveRecordSubscriber, ActiveStorageSubscriber, ActiveSupportCacheMultiSubscriber, ActiveSupportCacheSubscriber
Instance Method Summary collapse
- #finish(name, id, payload) ⇒ Object
- #format_payload(payload) ⇒ Object
- #process?(event, payload) ⇒ Boolean
- #record(name, payload) ⇒ Object
- #record_metrics(name, payload) ⇒ Object
- #start(name, id, payload) ⇒ Object
Methods included from InstrumentationHelper
#decrement_counter, #extract_attributes, #extract_callable, #gauge, #histogram, #increment_counter, #metric_agent, #metric_attributes, #metric_instrumentation, #metric_source, #monotonic_timer, #time
Instance Method Details
#finish(name, id, payload) ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/honeybadger/notification_subscriber.rb', line 12 def finish(name, id, payload) finish_time = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC) return unless process?(name, payload) payload = { instrumenter_id: id, duration: ((finish_time - payload.delete(:_start_time)) * 1000).round(2) }.merge(format_payload(payload).compact) record(name, payload) end |
#format_payload(payload) ⇒ Object
54 55 56 |
# File 'lib/honeybadger/notification_subscriber.rb', line 54 def format_payload(payload) payload end |
#process?(event, payload) ⇒ Boolean
50 51 52 |
# File 'lib/honeybadger/notification_subscriber.rb', line 50 def process?(event, payload) true end |
#record(name, payload) ⇒ Object
24 25 26 27 28 29 30 31 32 33 |
# File 'lib/honeybadger/notification_subscriber.rb', line 24 def record(name, payload) if Honeybadger.config.load_plugin_insights_events?(:rails) Honeybadger.event(name, payload) end if Honeybadger.config.load_plugin_insights_metrics?(:rails) metric_source 'rails' record_metrics(name, payload) end end |
#record_metrics(name, payload) ⇒ Object
35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/honeybadger/notification_subscriber.rb', line 35 def record_metrics(name, payload) case name when 'sql.active_record' gauge('duration.sql.active_record', value: payload[:duration], **payload.slice(:query)) when 'process_action.action_controller' gauge('duration.process_action.action_controller', value: payload[:duration], **payload.slice(:method, :controller, :action, :format, :status)) gauge('db_runtime.process_action.action_controller', value: payload[:db_runtime], **payload.slice(:method, :controller, :action, :format, :status)) gauge('view_runtime.process_action.action_controller', value: payload[:view_runtime], **payload.slice(:method, :controller, :action, :format, :status)) when 'perform.active_job' gauge('duration.perform.active_job', value: payload[:duration], **payload.slice(:job_class, :queue_name)) when /^cache_.*.active_support$/ gauge("duration.#{name}", value: payload[:duration], **payload.slice(:store, :key)) end end |
#start(name, id, payload) ⇒ Object
8 9 10 |
# File 'lib/honeybadger/notification_subscriber.rb', line 8 def start(name, id, payload) payload[:_start_time] = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC) end |