diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-07-19 17:16:28 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-07-19 17:16:28 +0300 |
commit | e4384360a16dd9a19d4d2d25d0ef1f2b862ed2a6 (patch) | |
tree | 2fcdfa7dcdb9db8f5208b2562f4b4e803d671243 /app/workers/ci/pipeline_cleanup_ref_worker.rb | |
parent | ffda4e7bcac36987f936b4ba515995a6698698f0 (diff) |
Add latest changes from gitlab-org/gitlab@16-2-stable-eev16.2.0-rc42
Diffstat (limited to 'app/workers/ci/pipeline_cleanup_ref_worker.rb')
-rw-r--r-- | app/workers/ci/pipeline_cleanup_ref_worker.rb | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/app/workers/ci/pipeline_cleanup_ref_worker.rb b/app/workers/ci/pipeline_cleanup_ref_worker.rb new file mode 100644 index 00000000000..291e1090c18 --- /dev/null +++ b/app/workers/ci/pipeline_cleanup_ref_worker.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true + +module Ci + class PipelineCleanupRefWorker + include ApplicationWorker + include Projects::RemoveRefs + + sidekiq_options retry: 3 + include PipelineQueue + + idempotent! + deduplicate :until_executed, if_deduplicated: :reschedule_once, ttl: 1.minute + data_consistency :always # rubocop:disable SidekiqLoadBalancing/WorkerDataConsistency + + urgency :low + + # Even though this worker is de-duplicated we need to acquire lock + # on a project to avoid running many concurrent refs removals + # + # TODO: Once underlying fix is done we can remove `in_lock` + # + # Related to: + # - https://gitlab.com/gitlab-org/gitaly/-/issues/5368 + # - https://gitlab.com/gitlab-org/gitaly/-/issues/5369 + def perform(pipeline_id) + pipeline = Ci::Pipeline.find_by_id(pipeline_id) + return unless pipeline + return unless pipeline.persistent_ref.should_delete? + + serialized_remove_refs(pipeline.project_id) do + pipeline.reset.persistent_ref.delete + end + end + end +end |