Commit 5971cd15 authored by Stan Hu's avatar Stan Hu

Merge branch '65278-fix-puma-master-counter-wipe' into 'master'

Fix active metric files being wiped after the app starts

See merge request gitlab-org/gitlab-ce!31668
parents 7a22b4ba 35fb27db
---
title: Fix active metric files being wiped after the app starts
merge_request: 31668
author:
type: fixed
...@@ -17,7 +17,25 @@ end ...@@ -17,7 +17,25 @@ end
require ::File.expand_path('../config/environment', __FILE__) require ::File.expand_path('../config/environment', __FILE__)
# The following is necessary to ensure stale Prometheus metrics don't accumulate over time.
# It needs to be done as early as here to ensure metrics files aren't deleted.
# After we hit our app in `warmup`, first metrics and corresponding files already being created,
# for example in `lib/gitlab/metrics/requests_rack_middleware.rb`.
def cleanup_prometheus_multiproc_dir
if dir = ::Prometheus::Client.configuration.multiprocess_files_dir
old_metrics = Dir[File.join(dir, '*.db')]
FileUtils.rm_rf(old_metrics)
end
end
def master_process?
Prometheus::PidProvider.worker_id.in? %w(unicorn_master puma_master)
end
warmup do |app| warmup do |app|
cleanup_prometheus_multiproc_dir if master_process?
client = Rack::MockRequest.new(app) client = Rack::MockRequest.new(app)
client.get('/') client.get('/')
end end
......
...@@ -51,22 +51,3 @@ if !Rails.env.test? && Gitlab::Metrics.prometheus_metrics_enabled? ...@@ -51,22 +51,3 @@ if !Rails.env.test? && Gitlab::Metrics.prometheus_metrics_enabled?
end end
end end
end end
def cleanup_prometheus_multiproc_dir
# The following is necessary to ensure stale Prometheus metrics don't
# accumulate over time. It needs to be done in this hook as opposed to
# inside an init script to ensure metrics files aren't deleted after new
# unicorn workers start after a SIGUSR2 is received.
if dir = ::Prometheus::Client.configuration.multiprocess_files_dir
old_metrics = Dir[File.join(dir, '*.db')]
FileUtils.rm_rf(old_metrics)
end
end
Gitlab::Cluster::LifecycleEvents.on_master_start do
cleanup_prometheus_multiproc_dir
end
Gitlab::Cluster::LifecycleEvents.on_master_restart do
cleanup_prometheus_multiproc_dir
end
...@@ -15,9 +15,7 @@ module Gitlab ...@@ -15,9 +15,7 @@ module Gitlab
private private
def log_termination(worker) def log_termination(worker)
labels = { worker: "worker_#{worker.index}" } @counter.increment
@counter.increment(labels)
end end
end end
end end
......
...@@ -17,9 +17,7 @@ describe Gitlab::Cluster::PumaWorkerKillerObserver do ...@@ -17,9 +17,7 @@ describe Gitlab::Cluster::PumaWorkerKillerObserver do
it 'increments timeout counter' do it 'increments timeout counter' do
worker = double(index: 0) worker = double(index: 0)
expect(counter) expect(counter).to receive(:increment)
.to receive(:increment)
.with({ worker: 'worker_0' })
subject.callback.call(worker) subject.callback.call(worker)
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