2017-09-10 17:25:29 +05:30
|
|
|
module Gitlab
|
|
|
|
module Prometheus
|
|
|
|
module Queries
|
|
|
|
class DeploymentQuery < BaseQuery
|
2018-12-05 23:21:45 +05:30
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
2018-03-27 19:54:05 +05:30
|
|
|
def query(deployment_id)
|
2017-09-10 17:25:29 +05:30
|
|
|
Deployment.find_by(id: deployment_id).try do |deployment|
|
|
|
|
environment_slug = deployment.environment.slug
|
|
|
|
|
|
|
|
memory_query = raw_memory_usage_query(environment_slug)
|
|
|
|
memory_avg_query = %{avg(avg_over_time(container_memory_usage_bytes{container_name!="POD",environment="#{environment_slug}"}[30m]))}
|
|
|
|
cpu_query = raw_cpu_usage_query(environment_slug)
|
|
|
|
cpu_avg_query = %{avg(rate(container_cpu_usage_seconds_total{container_name!="POD",environment="#{environment_slug}"}[30m])) * 100}
|
|
|
|
|
|
|
|
timeframe_start = (deployment.created_at - 30.minutes).to_f
|
|
|
|
timeframe_end = (deployment.created_at + 30.minutes).to_f
|
|
|
|
|
|
|
|
{
|
|
|
|
memory_values: client_query_range(memory_query, start: timeframe_start, stop: timeframe_end),
|
|
|
|
memory_before: client_query(memory_avg_query, time: deployment.created_at.to_f),
|
|
|
|
memory_after: client_query(memory_avg_query, time: timeframe_end),
|
|
|
|
|
|
|
|
cpu_values: client_query_range(cpu_query, start: timeframe_start, stop: timeframe_end),
|
|
|
|
cpu_before: client_query(cpu_avg_query, time: deployment.created_at.to_f),
|
|
|
|
cpu_after: client_query(cpu_avg_query, time: timeframe_end)
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
2018-12-05 23:21:45 +05:30
|
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
2018-03-27 19:54:05 +05:30
|
|
|
|
|
|
|
def self.transform_reactive_result(result)
|
|
|
|
result[:metrics] = result.delete :data
|
|
|
|
result
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|