debian-mirror-gitlab/config.ru

47 lines
1.4 KiB
Text
Raw Normal View History

2014-09-02 18:07:02 +05:30
# This file is used by Rack-based servers to start the application.
if defined?(Unicorn)
require 'unicorn'
2015-09-11 14:41:01 +05:30
if ENV['RAILS_ENV'] == 'production' || ENV['RAILS_ENV'] == 'staging'
# Unicorn self-process killer
require 'unicorn/worker_killer'
2018-05-09 12:01:36 +05:30
min = (ENV['GITLAB_UNICORN_MEMORY_MIN'] || 400 * 1 << 20).to_i
max = (ENV['GITLAB_UNICORN_MEMORY_MAX'] || 650 * 1 << 20).to_i
2016-01-29 22:53:50 +05:30
2015-09-11 14:41:01 +05:30
# Max memory size (RSS) per worker
2016-01-29 22:53:50 +05:30
use Unicorn::WorkerKiller::Oom, min, max
2015-09-11 14:41:01 +05:30
end
2014-09-02 18:07:02 +05:30
end
2019-03-02 22:35:43 +05:30
require ::File.expand_path('../config/environment', __FILE__)
2014-09-02 18:07:02 +05:30
2019-10-12 21:52:04 +05:30
# 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
2018-03-17 18:26:18 +05:30
warmup do |app|
2019-10-12 21:52:04 +05:30
cleanup_prometheus_multiproc_dir if master_process?
2018-03-17 18:26:18 +05:30
client = Rack::MockRequest.new(app)
client.get('/')
end
2014-09-02 18:07:02 +05:30
map ENV['RAILS_RELATIVE_URL_ROOT'] || "/" do
2018-03-27 19:54:05 +05:30
use Gitlab::Middleware::ReleaseEnv
2014-09-02 18:07:02 +05:30
run Gitlab::Application
end