Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
a38ecbc1
Commit
a38ecbc1
authored
Jan 24, 2022
by
Quang-Minh Nguyen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make repository pull mirroring not depend on sidekiq queue sizes
Issue:
https://gitlab.com/gitlab-org/gitlab/-/issues/340630
parent
d75114c8
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
80 additions
and
6 deletions
+80
-6
ee/app/workers/project_import_schedule_worker.rb
ee/app/workers/project_import_schedule_worker.rb
+18
-0
ee/app/workers/update_all_mirrors_worker.rb
ee/app/workers/update_all_mirrors_worker.rb
+13
-6
ee/spec/workers/project_import_schedule_worker_spec.rb
ee/spec/workers/project_import_schedule_worker_spec.rb
+14
-0
ee/spec/workers/update_all_mirrors_worker_spec.rb
ee/spec/workers/update_all_mirrors_worker_spec.rb
+35
-0
No files found.
ee/app/workers/project_import_schedule_worker.rb
View file @
a38ecbc1
...
...
@@ -4,6 +4,10 @@ class ProjectImportScheduleWorker
ImportStateNotFound
=
Class
.
new
(
StandardError
)
include
ApplicationWorker
# At the moment, this inclusion is to enable job tracking ability. In the
# future, the capacity management should be moved to this worker instead of
# UpdateAllMirrorsWorker
include
LimitedCapacity
::
Worker
data_consistency
:always
prepend
WaitableWorker
...
...
@@ -21,6 +25,8 @@ class ProjectImportScheduleWorker
tags
:needs_own_queue
def
perform
(
project_id
)
job_tracker
.
register
(
jid
,
capacity
)
return
if
Gitlab
::
Database
.
read_only?
project
=
Project
.
with_route
.
with_import_state
.
with_namespace
.
find_by_id
(
project_id
)
...
...
@@ -29,5 +35,17 @@ class ProjectImportScheduleWorker
with_context
(
project:
project
)
do
project
.
import_state
.
schedule
end
ensure
job_tracker
.
remove
(
jid
)
end
private
def
capacity
Gitlab
::
Mirror
.
available_capacity
end
def
job_tracker
@job_tracker
||=
LimitedCapacity
::
JobTracker
.
new
(
self
.
class
.
name
)
end
end
ee/app/workers/update_all_mirrors_worker.rb
View file @
a38ecbc1
...
...
@@ -18,7 +18,16 @@ class UpdateAllMirrorsWorker # rubocop:disable Scalability/IdempotentWorker
scheduled
=
0
with_lease
do
# Clean-up completed jobs with stale status
job_tracker
.
clean_up
scheduled
=
schedule_mirrors!
if
scheduled
>
0
# Wait for all ProjectImportScheduleWorker jobs to complete
deadline
=
Time
.
current
+
SCHEDULE_WAIT_TIMEOUT
sleep
1
while
job_tracker
.
count
>
0
&&
Time
.
current
<
deadline
end
end
# If we didn't get the lease, or no updates were scheduled, exit early
...
...
@@ -73,12 +82,6 @@ class UpdateAllMirrorsWorker # rubocop:disable Scalability/IdempotentWorker
last
=
projects
.
last
.
import_state
.
next_execution_timestamp
end
if
scheduled
>
0
# Wait for all ProjectImportScheduleWorker jobs to complete
deadline
=
Time
.
current
+
SCHEDULE_WAIT_TIMEOUT
sleep
1
while
ProjectImportScheduleWorker
.
queue_size
>
0
&&
Time
.
current
<
deadline
end
scheduled
end
# rubocop: enable CodeReuse/ActiveRecord
...
...
@@ -156,4 +159,8 @@ class UpdateAllMirrorsWorker # rubocop:disable Scalability/IdempotentWorker
end
.
to_sql
end
# rubocop: enable CodeReuse/ActiveRecord
def
job_tracker
@job_tracker
||=
LimitedCapacity
::
JobTracker
.
new
(
ProjectImportScheduleWorker
.
name
)
end
end
ee/spec/workers/project_import_schedule_worker_spec.rb
View file @
a38ecbc1
...
...
@@ -11,7 +11,14 @@ RSpec.describe ProjectImportScheduleWorker do
let
(
:job_args
)
{
[
project
.
id
]
}
let
(
:job_tracker_instance
)
{
double
(
LimitedCapacity
::
JobTracker
)
}
before
do
allow
(
Gitlab
::
Mirror
).
to
receive
(
:available_capacity
).
and_return
(
5
)
allow
(
LimitedCapacity
::
JobTracker
).
to
receive
(
:new
).
with
(
'ProjectImportScheduleWorker'
).
and_return
(
job_tracker_instance
)
allow
(
job_tracker_instance
).
to
receive
(
:register
)
allow
(
job_tracker_instance
).
to
receive
(
:remove
)
allow
(
Project
).
to
receive
(
:find_by_id
).
with
(
project
.
id
).
and_return
(
project
)
allow
(
project
).
to
receive
(
:add_import_job
)
end
...
...
@@ -31,6 +38,13 @@ RSpec.describe ProjectImportScheduleWorker do
expect
(
import_state
).
to
be_scheduled
end
it
'tracks the status of the worker'
do
subject
expect
(
job_tracker_instance
).
to
have_received
(
:register
).
with
(
any_args
,
5
).
at_least
(
:once
)
expect
(
job_tracker_instance
).
to
have_received
(
:remove
).
with
(
any_args
).
at_least
(
:once
)
end
end
context
'project is not found'
do
...
...
ee/spec/workers/update_all_mirrors_worker_spec.rb
View file @
a38ecbc1
...
...
@@ -56,8 +56,17 @@ RSpec.describe UpdateAllMirrorsWorker do
end
context
'when updates were scheduled'
do
let
(
:job_tracker_instance
)
{
double
(
LimitedCapacity
::
JobTracker
)
}
before
do
allow
(
worker
).
to
receive
(
:schedule_mirrors!
).
and_return
(
1
)
allow
(
LimitedCapacity
::
JobTracker
).
to
receive
(
:new
).
with
(
'ProjectImportScheduleWorker'
).
and_return
(
job_tracker_instance
)
count
=
3
allow
(
job_tracker_instance
).
to
receive
(
:clean_up
)
allow
(
job_tracker_instance
).
to
receive
(
:register
)
allow
(
job_tracker_instance
).
to
receive
(
:remove
)
allow
(
job_tracker_instance
).
to
receive
(
:count
)
{
|
_
|
count
-=
1
}
end
it
'sleeps a bit after scheduling mirrors'
do
...
...
@@ -66,6 +75,18 @@ RSpec.describe UpdateAllMirrorsWorker do
worker
.
perform
end
it
'cleans up finished ProjectImportSchduleWorker jobs'
do
worker
.
perform
expect
(
job_tracker_instance
).
to
have_received
(
:clean_up
).
once
end
it
'waits until all ProjectImportSchduleWorker jobs to complete'
do
worker
.
perform
expect
(
job_tracker_instance
).
to
have_received
(
:count
).
exactly
(
3
).
times
end
context
'if capacity is available'
do
before
do
allow
(
Gitlab
::
Mirror
).
to
receive
(
:reschedule_immediately?
).
and_return
(
true
)
...
...
@@ -102,6 +123,20 @@ RSpec.describe UpdateAllMirrorsWorker do
worker
.
perform
end
it
'does not poll for ProjectImportSchduleWorker jobs to complete'
do
expect_next_instance_of
(
LimitedCapacity
::
JobTracker
)
do
|
instance
|
expect
(
instance
).
not_to
receive
(
:count
)
end
worker
.
perform
end
it
'does not wait'
do
expect
(
Kernel
).
not_to
receive
(
:sleep
)
worker
.
perform
end
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment