Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYorick Peterse <yorickpeterse@gmail.com>2015-12-14 18:51:38 +0300
committerYorick Peterse <yorickpeterse@gmail.com>2015-12-17 19:25:48 +0300
commit9f95ff0d90802467a04816f1d38e30770a026820 (patch)
tree043ade2a781f74ec4105f7d2882e587b7c24c448 /lib/gitlab/metrics/subscribers
parentd0352e6604915a1a94fbe84252d1606f5adac57c (diff)
Track location information as tags
This allows the information to be displayed when using certain functions (e.g. top()) as well as making it easier to aggregate on a per file basis.
Diffstat (limited to 'lib/gitlab/metrics/subscribers')
-rw-r--r--lib/gitlab/metrics/subscribers/action_view.rb17
-rw-r--r--lib/gitlab/metrics/subscribers/active_record.rb17
2 files changed, 22 insertions, 12 deletions
diff --git a/lib/gitlab/metrics/subscribers/action_view.rb b/lib/gitlab/metrics/subscribers/action_view.rb
index 2e88e4bea6a..7e0dcf99d92 100644
--- a/lib/gitlab/metrics/subscribers/action_view.rb
+++ b/lib/gitlab/metrics/subscribers/action_view.rb
@@ -16,10 +16,10 @@ module Gitlab
private
def track(event)
- path = relative_path(event.payload[:identifier])
values = values_for(event)
+ tags = tags_for(event)
- current_transaction.add_metric(SERIES, values, path: path)
+ current_transaction.add_metric(SERIES, values, tags)
end
def relative_path(path)
@@ -27,16 +27,21 @@ module Gitlab
end
def values_for(event)
- values = { duration: event.duration }
+ { duration: event.duration }
+ end
+
+ def tags_for(event)
+ path = relative_path(event.payload[:identifier])
+ tags = { view: path }
file, line = Metrics.last_relative_application_frame
if file and line
- values[:file] = file
- values[:line] = line
+ tags[:file] = file
+ tags[:line] = line
end
- values
+ tags
end
def current_transaction
diff --git a/lib/gitlab/metrics/subscribers/active_record.rb b/lib/gitlab/metrics/subscribers/active_record.rb
index 3cc9b1addf6..d947c128ce2 100644
--- a/lib/gitlab/metrics/subscribers/active_record.rb
+++ b/lib/gitlab/metrics/subscribers/active_record.rb
@@ -13,25 +13,30 @@ module Gitlab
def sql(event)
return unless current_transaction
- sql = ObfuscatedSQL.new(event.payload[:sql]).to_s
values = values_for(event)
+ tags = tags_for(event)
- current_transaction.add_metric(SERIES, values, sql: sql)
+ current_transaction.add_metric(SERIES, values, tags)
end
private
def values_for(event)
- values = { duration: event.duration }
+ { duration: event.duration }
+ end
+
+ def tags_for(event)
+ sql = ObfuscatedSQL.new(event.payload[:sql]).to_s
+ tags = { sql: sql }
file, line = Metrics.last_relative_application_frame
if file and line
- values[:file] = file
- values[:line] = line
+ tags[:file] = file
+ tags[:line] = line
end
- values
+ tags
end
def current_transaction