debian-mirror-gitlab/lib/tasks/gitlab/sidekiq.rake

140 lines
5.2 KiB
Ruby
Raw Normal View History

2020-03-13 15:44:24 +05:30
# frozen_string_literal: true
namespace :gitlab do
namespace :sidekiq do
def write_yaml(path, banner, object)
2020-11-24 15:15:51 +05:30
File.write(path, banner + YAML.dump(object).gsub(/ *$/m, ''))
2020-03-13 15:44:24 +05:30
end
2021-06-08 01:23:25 +05:30
namespace :migrate_jobs do
desc 'GitLab | Sidekiq | Migrate jobs in the scheduled set to new queue names'
task schedule: :environment do
::Gitlab::SidekiqMigrateJobs
2023-03-04 22:38:38 +05:30
.new(::Gitlab::SidekiqConfig.worker_queue_mappings, logger: Logger.new($stdout))
2023-01-13 00:05:48 +05:30
.migrate_set('schedule')
2021-06-08 01:23:25 +05:30
end
desc 'GitLab | Sidekiq | Migrate jobs in the retry set to new queue names'
task retry: :environment do
::Gitlab::SidekiqMigrateJobs
2023-03-04 22:38:38 +05:30
.new(::Gitlab::SidekiqConfig.worker_queue_mappings, logger: Logger.new($stdout))
2023-01-13 00:05:48 +05:30
.migrate_set('retry')
end
desc 'GitLab | Sidekiq | Migrate jobs in queues outside of routing rules'
task queued: :environment do
::Gitlab::SidekiqMigrateJobs
2023-03-04 22:38:38 +05:30
.new(::Gitlab::SidekiqConfig.worker_queue_mappings, logger: Logger.new($stdout))
2023-01-13 00:05:48 +05:30
.migrate_queues
2021-06-08 01:23:25 +05:30
end
end
2021-09-30 23:02:18 +05:30
task :not_production do
raise 'This task cannot be run in the production environment' if Rails.env.production?
end
2020-03-13 15:44:24 +05:30
namespace :all_queues_yml do
desc 'GitLab | Sidekiq | Generate all_queues.yml based on worker definitions'
2021-09-30 23:02:18 +05:30
task generate: ['gitlab:sidekiq:not_production', :environment] do
2020-03-13 15:44:24 +05:30
banner = <<~BANNER
# This file is generated automatically by
# bin/rake gitlab:sidekiq:all_queues_yml:generate
#
# Do not edit it manually!
BANNER
2021-12-11 22:18:48 +05:30
foss_workers, ee_workers, jh_workers = Gitlab::SidekiqConfig.workers_for_all_queues_yml
2020-03-13 15:44:24 +05:30
write_yaml(Gitlab::SidekiqConfig::FOSS_QUEUE_CONFIG_PATH, banner, foss_workers)
if Gitlab.ee?
write_yaml(Gitlab::SidekiqConfig::EE_QUEUE_CONFIG_PATH, banner, ee_workers)
end
2021-12-11 22:18:48 +05:30
if Gitlab.jh?
write_yaml(Gitlab::SidekiqConfig::JH_QUEUE_CONFIG_PATH, banner, jh_workers)
end
2020-03-13 15:44:24 +05:30
end
desc 'GitLab | Sidekiq | Validate that all_queues.yml matches worker definitions'
2021-09-30 23:02:18 +05:30
task check: ['gitlab:sidekiq:not_production', :environment] do
2020-03-13 15:44:24 +05:30
if Gitlab::SidekiqConfig.all_queues_yml_outdated?
raise <<~MSG
Changes in worker queues found, please update the metadata by running:
bin/rake gitlab:sidekiq:all_queues_yml:generate
Then commit and push the changes from:
- #{Gitlab::SidekiqConfig::FOSS_QUEUE_CONFIG_PATH}
- #{Gitlab::SidekiqConfig::EE_QUEUE_CONFIG_PATH}
2021-12-11 22:18:48 +05:30
#{"- " + Gitlab::SidekiqConfig::JH_QUEUE_CONFIG_PATH if Gitlab.jh?}
2020-03-13 15:44:24 +05:30
MSG
end
end
end
namespace :sidekiq_queues_yml do
desc 'GitLab | Sidekiq | Generate sidekiq_queues.yml based on worker definitions'
2021-09-30 23:02:18 +05:30
task generate: ['gitlab:sidekiq:not_production', :environment] do
2020-03-13 15:44:24 +05:30
banner = <<~BANNER
# This file is generated automatically by
# bin/rake gitlab:sidekiq:sidekiq_queues_yml:generate
#
# Do not edit it manually!
#
# This configuration file should be exclusively used to set queue settings for
# Sidekiq. Any other setting should be specified using the Sidekiq CLI or the
# Sidekiq Ruby API (see config/initializers/sidekiq.rb).
#
# All the queues to process and their weights. Every queue _must_ have a weight
# defined.
#
# The available weights are as follows
#
# 1: low priority
# 2: medium priority
# 3: high priority
# 5: _super_ high priority, this should only be used for _very_ important queues
#
2021-11-11 11:23:49 +05:30
# The formula for calculating the likelihood of a job being popped off a queue
# (given all queues have work to perform) is:
2020-03-13 15:44:24 +05:30
#
# chance = (queue weight / total weight of all queues) * 100
BANNER
queues_and_weights = Gitlab::SidekiqConfig.queues_for_sidekiq_queues_yml
write_yaml(Gitlab::SidekiqConfig::SIDEKIQ_QUEUES_PATH, banner, queues: queues_and_weights)
2022-01-26 12:08:38 +05:30
if Gitlab.jh?
write_yaml(Gitlab::SidekiqConfig::JH_SIDEKIQ_QUEUES_PATH, banner, queues: Gitlab::SidekiqConfig.jh_queues_for_sidekiq_queues_yml)
end
2020-03-13 15:44:24 +05:30
end
desc 'GitLab | Sidekiq | Validate that sidekiq_queues.yml matches worker definitions'
2021-09-30 23:02:18 +05:30
task check: ['gitlab:sidekiq:not_production', :environment] do
2020-03-13 15:44:24 +05:30
if Gitlab::SidekiqConfig.sidekiq_queues_yml_outdated?
raise <<~MSG
Changes in worker queues found, please update the metadata by running:
bin/rake gitlab:sidekiq:sidekiq_queues_yml:generate
Then commit and push the changes from:
- #{Gitlab::SidekiqConfig::SIDEKIQ_QUEUES_PATH}
2022-01-26 12:08:38 +05:30
#{"- " + Gitlab::SidekiqConfig::JH_SIDEKIQ_QUEUES_PATH if Gitlab.jh?}
2020-03-13 15:44:24 +05:30
MSG
end
end
end
2023-03-04 22:38:38 +05:30
namespace :queues do
desc 'GitLab | Sidekiq | Validate all_queues.yml and sidekiq_queues.yml match worker definitions'
task check: ['gitlab:sidekiq:all_queues_yml:check', 'gitlab:sidekiq:sidekiq_queues_yml:check', :environment]
end
2020-03-13 15:44:24 +05:30
end
end