Class: Projects::ProcessSyncEventsWorker
- Inherits:
-
Object
- Object
- Projects::ProcessSyncEventsWorker
- Includes:
- ApplicationWorker
- Defined in:
- app/workers/projects/process_sync_events_worker.rb
Overview
This worker can be called multiple times at the same time but only one of them can process events at a time. This is ensured by ‘try_obtain_lease` in `Ci::ProcessSyncEventsService`. `until_executing` here is to reduce redundant worker enqueuing.
Constant Summary
Constants included from ApplicationWorker
ApplicationWorker::LOGGING_EXTRA_KEY, ApplicationWorker::SAFE_PUSH_BULK_LIMIT
Constants included from Gitlab::Loggable
Constants included from WorkerAttributes
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::Loggable
Methods included from Gitlab::SidekiqVersioning::Worker
Methods included from WorkerContext
Instance Method Details
#perform ⇒ Object
18 19 20 21 22 23 24 25 26 |
# File 'app/workers/projects/process_sync_events_worker.rb', line 18 def perform results = ::Ci::ProcessSyncEventsService.new( ::Projects::SyncEvent, ::Ci::ProjectMirror ).execute results.each do |key, value| (key, value) end end |