Commit 86527290 authored by James Fargher's avatar James Fargher

Wrap rails code in concurrent backups

Rails needs these extra blocks to prevent internal race conditions
parent f2c27366
---
title: Fix race condition in concurrent backups
merge_request: 39894
author:
type: fixed
......@@ -26,13 +26,17 @@ module Backup
threads = Gitlab.config.repositories.storages.keys.map do |storage|
Thread.new do
Rails.application.executor.wrap do
dump_storage(storage, semaphore, max_storage_concurrency: max_storage_concurrency)
rescue => e
errors << e
end
end
end
ActiveSupport::Dependencies.interlock.permit_concurrent_loads do
threads.each(&:join)
end
raise errors.pop unless errors.empty?
end
......@@ -155,6 +159,7 @@ module Backup
threads = Array.new(max_storage_concurrency) do
Thread.new do
Rails.application.executor.wrap do
while project = queue.pop
semaphore.acquire
......@@ -169,6 +174,7 @@ module Backup
end
end
end
end
Project.for_repository_storage(storage).find_each(batch_size: 100) do |project|
break unless errors.empty?
......@@ -177,7 +183,9 @@ module Backup
end
queue.close
ActiveSupport::Dependencies.interlock.permit_concurrent_loads do
threads.each(&:join)
end
raise errors.pop unless errors.empty?
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