2020-04-08 14:13:33 +05:30
|
|
|
# frozen_string_literal: true
|
2021-01-29 00:20:46 +05:30
|
|
|
module SidekiqLogArguments
|
|
|
|
def self.enabled?
|
|
|
|
Gitlab::Utils.to_boolean(ENV['SIDEKIQ_LOG_ARGUMENTS'], default: true)
|
|
|
|
end
|
|
|
|
end
|
2020-04-08 14:13:33 +05:30
|
|
|
|
2022-11-25 23:54:43 +05:30
|
|
|
def load_cron_jobs!
|
|
|
|
Sidekiq::Cron::Job.load_from_hash! Gitlab::SidekiqConfig.cron_jobs
|
|
|
|
|
|
|
|
Gitlab.ee do
|
|
|
|
Gitlab::Mirror.configure_cron_job!
|
|
|
|
|
|
|
|
Gitlab::Geo.configure_cron_jobs!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
def enable_reliable_fetch?
|
|
|
|
return true unless Feature::FlipperFeature.table_exists?
|
|
|
|
|
2022-07-16 23:28:13 +05:30
|
|
|
Feature.enabled?(:gitlab_sidekiq_reliable_fetcher, type: :ops)
|
2019-07-31 22:56:46 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def enable_semi_reliable_fetch_mode?
|
|
|
|
return true unless Feature::FlipperFeature.table_exists?
|
|
|
|
|
2022-07-16 23:28:13 +05:30
|
|
|
Feature.enabled?(:gitlab_sidekiq_enable_semi_reliable_fetcher, type: :ops)
|
2019-07-31 22:56:46 +05:30
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
# Custom Queues configuration
|
|
|
|
queues_config_hash = Gitlab::Redis::Queues.params
|
|
|
|
queues_config_hash[:namespace] = Gitlab::Redis::Queues::SIDEKIQ_NAMESPACE
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
enable_json_logs = Gitlab.config.sidekiq.log_format == 'json'
|
2023-03-04 22:38:38 +05:30
|
|
|
enable_sidekiq_memory_killer = ENV['SIDEKIQ_MEMORY_KILLER_MAX_RSS'].to_i.nonzero? &&
|
2023-04-23 21:23:45 +05:30
|
|
|
!Gitlab::Utils.to_boolean(ENV['GITLAB_MEMORY_WATCHDOG_ENABLED'], default: true)
|
2018-05-09 12:01:36 +05:30
|
|
|
|
2014-09-02 18:07:02 +05:30
|
|
|
Sidekiq.configure_server do |config|
|
2023-01-13 00:05:48 +05:30
|
|
|
config[:strict] = false
|
|
|
|
config[:queues] = Gitlab::SidekiqConfig.expand_queues(config[:queues])
|
2021-11-18 22:05:49 +05:30
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
if enable_json_logs
|
2021-11-18 22:05:49 +05:30
|
|
|
config.log_formatter = Gitlab::SidekiqLogging::JSONFormatter.new
|
2023-01-13 00:05:48 +05:30
|
|
|
config[:job_logger] = Gitlab::SidekiqLogging::StructuredLogger
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
# Remove the default-provided handler. The exception is logged inside
|
|
|
|
# Gitlab::SidekiqLogging::StructuredLogger
|
2023-01-13 00:05:48 +05:30
|
|
|
config.error_handlers.delete(Sidekiq::DEFAULT_ERROR_HANDLER)
|
2018-05-09 12:01:36 +05:30
|
|
|
end
|
|
|
|
|
2023-01-13 00:05:48 +05:30
|
|
|
Sidekiq.logger.info "Listening on queues #{config[:queues].uniq.sort}"
|
2022-05-07 20:08:51 +05:30
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
config.redis = queues_config_hash
|
|
|
|
|
2021-11-18 22:05:49 +05:30
|
|
|
config.server_middleware(&Gitlab::SidekiqMiddleware.server_configurator(
|
2020-04-08 14:13:33 +05:30
|
|
|
metrics: Settings.monitoring.sidekiq_exporter,
|
2022-11-25 23:54:43 +05:30
|
|
|
arguments_logger: SidekiqLogArguments.enabled? && !enable_json_logs
|
2021-11-18 22:05:49 +05:30
|
|
|
))
|
2020-04-08 14:13:33 +05:30
|
|
|
|
2020-01-01 13:55:28 +05:30
|
|
|
config.client_middleware(&Gitlab::SidekiqMiddleware.client_configurator)
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2021-02-22 17:27:13 +05:30
|
|
|
config.death_handlers << Gitlab::SidekiqDeathHandler.method(:handler)
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
config.on :startup do
|
|
|
|
# Clear any connections that might have been obtained before starting
|
|
|
|
# Sidekiq (e.g. in an initializer).
|
2022-07-16 23:28:13 +05:30
|
|
|
ActiveRecord::Base.clear_all_connections! # rubocop:disable Database/MultipleDatabases
|
2019-12-04 20:38:33 +05:30
|
|
|
|
2019-12-21 20:55:43 +05:30
|
|
|
# Start monitor to track running jobs. By default, cancel job is not enabled
|
|
|
|
# To cancel job, it requires `SIDEKIQ_MONITOR_WORKER=1` to enable notification channel
|
|
|
|
Gitlab::SidekiqDaemon::Monitor.instance.start
|
|
|
|
|
2022-11-25 23:54:43 +05:30
|
|
|
Gitlab::SidekiqDaemon::MemoryKiller.instance.start if enable_sidekiq_memory_killer
|
2022-07-16 23:28:13 +05:30
|
|
|
|
|
|
|
first_sidekiq_worker = !ENV['SIDEKIQ_WORKER_ID'] || ENV['SIDEKIQ_WORKER_ID'] == '0'
|
|
|
|
health_checks = Settings.monitoring.sidekiq_health_checks
|
|
|
|
|
|
|
|
# Start health-check in-process server
|
|
|
|
if first_sidekiq_worker && health_checks.enabled
|
|
|
|
Gitlab::HealthChecks::Server.instance(
|
|
|
|
address: health_checks.address,
|
|
|
|
port: health_checks.port
|
|
|
|
).start
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
2015-12-23 02:04:40 +05:30
|
|
|
|
2023-01-13 00:05:48 +05:30
|
|
|
config.on(:shutdown) do
|
|
|
|
Gitlab::Cluster::LifecycleEvents.do_worker_stop
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
if enable_reliable_fetch?
|
2023-01-13 00:05:48 +05:30
|
|
|
config[:semi_reliable_fetch] = enable_semi_reliable_fetch_mode?
|
2019-02-15 15:39:39 +05:30
|
|
|
Sidekiq::ReliableFetch.setup_reliable_fetch!(config)
|
2018-12-05 23:21:45 +05:30
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
Gitlab::SidekiqVersioning.install!
|
|
|
|
|
2023-01-13 00:05:48 +05:30
|
|
|
config[:cron_poll_interval] = Gitlab.config.cron_jobs.poll_interval
|
2022-11-25 23:54:43 +05:30
|
|
|
load_cron_jobs!
|
2016-06-22 15:30:34 +05:30
|
|
|
|
|
|
|
# Avoid autoload issue such as 'Mail::Parsers::AddressStruct'
|
|
|
|
# https://github.com/mikel/mail/issues/912#issuecomment-214850355
|
|
|
|
Mail.eager_autoload!
|
2019-07-07 11:18:12 +05:30
|
|
|
|
|
|
|
# Ensure the whole process group is terminated if possible
|
|
|
|
Gitlab::SidekiqSignals.install!(Sidekiq::CLI::SIGNAL_HANDLERS)
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
Sidekiq.configure_client do |config|
|
2017-09-10 17:25:29 +05:30
|
|
|
config.redis = queues_config_hash
|
2020-04-08 14:13:33 +05:30
|
|
|
# We only need to do this for other clients. If Sidekiq-server is the
|
|
|
|
# client scheduling jobs, we have access to the regular sidekiq logger that
|
|
|
|
# writes to STDOUT
|
|
|
|
Sidekiq.logger = Gitlab::SidekiqLogging::ClientLogger.build
|
|
|
|
Sidekiq.logger.formatter = Gitlab::SidekiqLogging::JSONFormatter.new if enable_json_logs
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2020-01-01 13:55:28 +05:30
|
|
|
config.client_middleware(&Gitlab::SidekiqMiddleware.client_configurator)
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
2021-12-07 22:27:20 +05:30
|
|
|
|
2022-01-26 12:08:38 +05:30
|
|
|
Sidekiq::Scheduled::Poller.prepend Gitlab::Patch::SidekiqPoller
|
|
|
|
Sidekiq::Cron::Poller.prepend Gitlab::Patch::SidekiqPoller
|
2023-01-13 00:05:48 +05:30
|
|
|
Sidekiq::Cron::Poller.prepend Gitlab::Patch::SidekiqCronPoller
|