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:
authorPawel Chojnacki <pawel@chojnacki.ws>2017-05-25 18:39:43 +0300
committerPawel Chojnacki <pawel@chojnacki.ws>2017-05-25 18:39:43 +0300
commit608186d54bb9aefb0b867c177ac62d534e8840ad (patch)
treec3ccf45692edd2b73dc9bdbfcf53500cce7532b0 /lib/gitlab/prometheus
parent4d8f3978a254f33d959de65dbf7b20a1d41a058d (diff)
Add per deployment additional metrics
Diffstat (limited to 'lib/gitlab/prometheus')
-rw-r--r--lib/gitlab/prometheus/queries/additional_metrics_deployment_query.rb17
-rw-r--r--lib/gitlab/prometheus/queries/additional_metrics_query.rb26
2 files changed, 32 insertions, 11 deletions
diff --git a/lib/gitlab/prometheus/queries/additional_metrics_deployment_query.rb b/lib/gitlab/prometheus/queries/additional_metrics_deployment_query.rb
new file mode 100644
index 00000000000..382052c298f
--- /dev/null
+++ b/lib/gitlab/prometheus/queries/additional_metrics_deployment_query.rb
@@ -0,0 +1,17 @@
+module Gitlab::Prometheus::Queries
+ class AdditionalMetricsDeploymentQuery < AdditionalMetricsQuery
+
+ def query(deployment_id)
+ deployment = Deployment.find_by(id: deployment_id)
+ query_context = {
+ environment_slug: deployment.environment.slug,
+ environment_filter: %{container_name!="POD",environment="#{deployment.environment.slug}"},
+ timeframe_start: (deployment.created_at - 30.minutes).to_f,
+ timeframe_end: (deployment.created_at + 30.minutes).to_f
+ }
+
+ query_metrics(query_context)
+ end
+ end
+end
+
diff --git a/lib/gitlab/prometheus/queries/additional_metrics_query.rb b/lib/gitlab/prometheus/queries/additional_metrics_query.rb
index de0dab0b19c..c48fcadee57 100644
--- a/lib/gitlab/prometheus/queries/additional_metrics_query.rb
+++ b/lib/gitlab/prometheus/queries/additional_metrics_query.rb
@@ -1,7 +1,21 @@
module Gitlab::Prometheus::Queries
class AdditionalMetricsQuery < BaseQuery
def query(environment_id)
- query_processor = method(:process_query).curry[query_context(environment_id)]
+ environment = Environment.find_by(id: environment_id)
+ query_context = {
+ environment_slug: environment.slug,
+ environment_filter: %{container_name!="POD",environment="#{environment.slug}"},
+ timeframe_start: 8.hours.ago.to_f,
+ timeframe_end: Time.now.to_f
+ }
+
+ query_metrics(query_context)
+ end
+
+ protected
+
+ def query_metrics(query_context)
+ query_processor = method(:process_query).curry[query_context]
matched_metrics.map do |group|
metrics = group.metrics.map do |metric|
@@ -22,16 +36,6 @@ module Gitlab::Prometheus::Queries
private
- def query_context(environment_id)
- environment = Environment.find_by(id: environment_id)
- {
- environment_slug: environment.slug,
- environment_filter: %{container_name!="POD",environment="#{environment.slug}"},
- timeframe_start: 8.hours.ago.to_f,
- timeframe_end: Time.now.to_f
- }
- end
-
def process_query(context, query)
query_with_result = query.dup
query_with_result[:result] =