about summary refs log tree commit diff
path: root/config/initializers/instrumentation.rb
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2017-01-26 19:08:05 +0100
committerEugen Rochko <eugen@zeonfederated.com>2017-01-26 19:08:05 +0100
commitd567f21d4f4c3feb09a08443cf75eb583904093b (patch)
tree79fdba0e0d0db6fc80ca57bffc7a55cc57bcb6c6 /config/initializers/instrumentation.rb
parent7329fbd8a453bbd2fcbec8bd63b1390bfe7bc7b8 (diff)
Improve StatsD instrumentation
Diffstat (limited to 'config/initializers/instrumentation.rb')
-rw-r--r--config/initializers/instrumentation.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/config/initializers/instrumentation.rb b/config/initializers/instrumentation.rb
new file mode 100644
index 000000000..8483f2be2
--- /dev/null
+++ b/config/initializers/instrumentation.rb
@@ -0,0 +1,18 @@
+# frozen_string_literal: true
+
+instrumentation_hostname = ENV.fetch('INSTRUMENTATION_HOSTNAME') { 'localhost' }
+
+ActiveSupport::Notifications.subscribe(/process_action.action_controller/) do |*args|
+  event      = ActiveSupport::Notifications::Event.new(*args)
+  controller = event.payload[:controller]
+  action     = event.payload[:action]
+  format     = event.payload[:format] || 'all'
+  format     = 'all' if format == '*/*'
+  status     = event.payload[:status]
+  key        = "#{controller}.#{action}.#{format}.#{instrumentation_hostname}"
+
+  ActiveSupport::Notifications.instrument :performance, action: :measure, measurement: "#{key}.total_duration", value: event.duration
+  ActiveSupport::Notifications.instrument :performance, action: :measure, measurement: "#{key}.db_time", value: event.payload[:db_runtime]
+  ActiveSupport::Notifications.instrument :performance, action: :measure, measurement: "#{key}.view_time", value: event.payload[:view_runtime]
+  ActiveSupport::Notifications.instrument :performance, measurement: "#{key}.status.#{status}"
+end