Commit 386a9d5e authored by Sean McGivern's avatar Sean McGivern

Merge branch '32648-dont-index-the-same-project-at-the-same-time' into 'master'

Add exclusive lock on project in ElasticCommitIndexerWorker

Closes #32648

See merge request gitlab-org/gitlab!35842
parents dc41ba4f f2545996
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
class ElasticCommitIndexerWorker class ElasticCommitIndexerWorker
include ApplicationWorker include ApplicationWorker
prepend Elastic::IndexingControl prepend Elastic::IndexingControl
include Gitlab::ExclusiveLeaseHelpers
feature_category :global_search feature_category :global_search
sidekiq_options retry: 2 sidekiq_options retry: 2
...@@ -24,6 +25,8 @@ class ElasticCommitIndexerWorker ...@@ -24,6 +25,8 @@ class ElasticCommitIndexerWorker
project = Project.find(project_id) project = Project.find(project_id)
return true unless project.use_elasticsearch? return true unless project.use_elasticsearch?
in_lock("#{self.class.name}/#{project_id}/#{wiki}", ttl: 1.hour, retries: 0) do
Gitlab::Elastic::Indexer.new(project, wiki: wiki).run Gitlab::Elastic::Indexer.new(project, wiki: wiki).run
end end
end
end end
---
title: Don't index the same project in Elasticsearch in parallel
merge_request: 35842
author:
type: performance
...@@ -34,5 +34,14 @@ RSpec.describe ElasticCommitIndexerWorker do ...@@ -34,5 +34,14 @@ RSpec.describe ElasticCommitIndexerWorker do
subject.perform(project.id, nil, nil, true) subject.perform(project.id, nil, nil, true)
end end
it 'does not run index when it is locked' do
expect(subject).to receive(:in_lock) # Mock and don't yield
.with("ElasticCommitIndexerWorker/#{project.id}/false", ttl: 1.hour, retries: 0)
expect(Gitlab::Elastic::Indexer).not_to receive(:new)
subject.perform(project.id)
end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment