Commit 254830c1 authored by Pawel Chojnacki's avatar Pawel Chojnacki

Move most of MetricsController logic to MetricsService

parent 466beeb3
require 'prometheus/client/formats/text'
class MetricsController < ActionController::Base class MetricsController < ActionController::Base
protect_from_forgery with: :exception protect_from_forgery with: :exception
before_action :validate_prometheus_metrics
include RequiresHealthToken include RequiresHealthToken
before_action :ensure_prometheus_metrics_are_enabled
CHECKS = [
Gitlab::HealthChecks::DbCheck,
Gitlab::HealthChecks::RedisCheck,
Gitlab::HealthChecks::FsShardsCheck
].freeze
def metrics def metrics
metrics_text = Prometheus::Client::Formats::Text.marshal_multiprocess(multiprocess_metrics_path) response = "#{metrics_service.health_metrics_text}\n#{metrics_service.prometheus_metrics_text}"
response = "#{health_metrics_text}\n#{metrics_text}"
render text: response, content_type: 'text/plain; version=0.0.4' render text: response, content_type: 'text/plain; version=0.0.4'
end end
private private
def ensure_prometheus_metrics_are_enabled def metrics_service
return render_404 unless Gitlab::Metrics.prometheus_metrics_enabled? @metrics_service ||= MetricsService.new
end end
def multiprocess_metrics_path def validate_prometheus_metrics
Rails.root.join(ENV['prometheus_multiproc_dir']) render_404 unless Gitlab::Metrics.prometheus_metrics_enabled?
end
def health_metrics_text
results = CHECKS.flat_map(&:metrics)
types = results.map(&:name).uniq.map { |metric_name| "# TYPE #{metric_name} gauge" }
metrics = results.map(&method(:metric_to_prom_line))
types.concat(metrics).join("\n")
end
def metric_to_prom_line(metric)
labels = metric.labels&.map { |key, value| "#{key}=\"#{value}\"" }&.join(',') || ''
if labels.empty?
"#{metric.name} #{metric.value}"
else
"#{metric.name}{#{labels}} #{metric.value}"
end
end end
end end
require 'prometheus/client/formats/text'
class MetricsService
CHECKS = [
Gitlab::HealthChecks::DbCheck,
Gitlab::HealthChecks::RedisCheck,
Gitlab::HealthChecks::FsShardsCheck
].freeze
def prometheus_metrics_text
Prometheus::Client::Formats::Text.marshal_multiprocess(multiprocess_metrics_path)
end
def health_metrics_text
results = CHECKS.flat_map(&:metrics)
types = results.map(&:name).uniq.map { |metric_name| "# TYPE #{metric_name} gauge" }
metrics = results.map(&method(:metric_to_prom_line))
types.concat(metrics).join("\n")
end
private
def multiprocess_metrics_path
Rails.root.join(ENV['prometheus_multiproc_dir'])
end
def metric_to_prom_line(metric)
labels = metric.labels&.map { |key, value| "#{key}=\"#{value}\"" }&.join(',') || ''
if labels.empty?
"#{metric.name} #{metric.value}"
else
"#{metric.name}{#{labels}} #{metric.value}"
end
end
end
...@@ -50,7 +50,9 @@ describe MetricsController do ...@@ -50,7 +50,9 @@ describe MetricsController do
end end
context 'prometheus metrics are disabled' do context 'prometheus metrics are disabled' do
before do
allow(Gitlab::Metrics).to receive(:prometheus_metrics_enabled?).and_return(false) allow(Gitlab::Metrics).to receive(:prometheus_metrics_enabled?).and_return(false)
end
it 'returns proper response' do it 'returns proper response' do
get :metrics get :metrics
...@@ -65,6 +67,5 @@ describe MetricsController do ...@@ -65,6 +67,5 @@ describe MetricsController do
expect(response.status).to eq(404) expect(response.status).to eq(404)
end end
end end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment