Class: PipelineScheduleWorker
- Inherits:
-
Object
- Object
- PipelineScheduleWorker
- Defined in:
- app/workers/pipeline_schedule_worker.rb
Overview
rubocop:disable Scalability/IdempotentWorker
Constant Summary collapse
- LOCK_RETRY =
3- LOCK_TTL =
5.minutes
- DELAY =
7.seconds
- BATCH_SIZE =
500
Constants included from Gitlab::ExclusiveLeaseHelpers
Gitlab::ExclusiveLeaseHelpers::FailedToObtainLockError
Constants included from ApplicationWorker
ApplicationWorker::LOGGING_EXTRA_KEY, ApplicationWorker::SAFE_PUSH_BULK_LIMIT
Constants included from Gitlab::Loggable
Constants included from WorkerAttributes
WorkerAttributes::DEFAULT_CONCURRENCY_LIMIT_PERCENTAGE_BY_URGENCY, WorkerAttributes::DEFAULT_DATA_CONSISTENCY, WorkerAttributes::DEFAULT_DATA_CONSISTENCY_PER_DB, WorkerAttributes::DEFAULT_DEFER_DELAY, WorkerAttributes::LOAD_BALANCED_DATA_CONSISTENCIES, WorkerAttributes::NAMESPACE_WEIGHTS, WorkerAttributes::VALID_DATA_CONSISTENCIES, WorkerAttributes::VALID_RESOURCE_BOUNDARIES, WorkerAttributes::VALID_URGENCIES
Instance Method Summary collapse
Methods included from Gitlab::ExclusiveLeaseHelpers
Methods included from Gitlab::Loggable
Methods included from Gitlab::SidekiqVersioning::Worker
Methods included from WorkerContext
Instance Method Details
#perform ⇒ Object
19 20 21 22 23 24 25 26 27 28 29 |
# File 'app/workers/pipeline_schedule_worker.rb', line 19 def perform in_lock(lock_key, **lock_params) do Ci::PipelineSchedule .select(:id, :owner_id, :project_id) # Minimize the selected columns .runnable_schedules .preloaded .find_in_batches(batch_size: BATCH_SIZE).with_index do |schedules, index| # rubocop: disable CodeReuse/ActiveRecord -- activates because of batch_size enqueue_run_pipeline_schedule_worker(schedules, index) end end end |