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
fe46d403
Commit
fe46d403
authored
Oct 20, 2017
by
Nick Thomas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Geo: Don't retry repositories or files until everything has been backfilled
parent
c2809c54
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
39 additions
and
23 deletions
+39
-23
app/workers/geo/file_download_dispatch_worker.rb
app/workers/geo/file_download_dispatch_worker.rb
+17
-14
app/workers/geo/repository_sync_worker.rb
app/workers/geo/repository_sync_worker.rb
+12
-8
changelogs/unreleased-ee/3810-geo-disable-retries.yml
changelogs/unreleased-ee/3810-geo-disable-retries.yml
+5
-0
spec/workers/geo/repository_sync_worker_spec.rb
spec/workers/geo/repository_sync_worker_spec.rb
+5
-1
No files found.
app/workers/geo/file_download_dispatch_worker.rb
View file @
fe46d403
...
@@ -13,23 +13,27 @@ module Geo
...
@@ -13,23 +13,27 @@ module Geo
end
end
def
load_pending_resources
def
load_pending_resources
unsynced
=
find_unsynced_objects
resources
=
find_unsynced_objects
(
batch_size:
db_retrieve_batch_size
)
failed
=
find_failed_objects
remaining_capacity
=
db_retrieve_batch_size
-
resources
.
count
interleave
(
unsynced
,
failed
)
if
remaining_capacity
.
zero?
resources
else
resources
+
find_failed_objects
(
batch_size:
remaining_capacity
)
end
end
end
def
find_unsynced_objects
def
find_unsynced_objects
(
batch_size
:)
lfs_object_ids
=
find_lfs_object_ids
lfs_object_ids
=
find_lfs_object_ids
(
batch_size:
batch_size
)
upload_objects_ids
=
find_upload_object_ids
upload_objects_ids
=
find_upload_object_ids
(
batch_size:
batch_size
)
interleave
(
lfs_object_ids
,
upload_objects_ids
)
interleave
(
lfs_object_ids
,
upload_objects_ids
)
end
end
def
find_failed_objects
def
find_failed_objects
(
batch_size
:)
Geo
::
FileRegistry
Geo
::
FileRegistry
.
failed
.
failed
.
limit
(
db_retrieve_
batch_size
)
.
limit
(
batch_size
)
.
pluck
(
:file_id
,
:file_type
)
.
pluck
(
:file_id
,
:file_type
)
end
end
...
@@ -37,7 +41,7 @@ module Geo
...
@@ -37,7 +41,7 @@ module Geo
current_node
.
restricted_project_ids
current_node
.
restricted_project_ids
end
end
def
find_lfs_object_ids
def
find_lfs_object_ids
(
batch_size
:)
# Selective project replication adds a wrinkle to FDW queries, so
# Selective project replication adds a wrinkle to FDW queries, so
# we fallback to the legacy version for now.
# we fallback to the legacy version for now.
relation
=
relation
=
...
@@ -48,12 +52,12 @@ module Geo
...
@@ -48,12 +52,12 @@ module Geo
end
end
relation
relation
.
limit
(
db_retrieve_
batch_size
)
.
limit
(
batch_size
)
.
pluck
(
:id
)
.
pluck
(
:id
)
.
map
{
|
id
|
[
id
,
:lfs
]
}
.
map
{
|
id
|
[
id
,
:lfs
]
}
end
end
def
find_upload_object_ids
def
find_upload_object_ids
(
batch_size
:)
# Selective project replication adds a wrinkle to FDW queries, so
# Selective project replication adds a wrinkle to FDW queries, so
# we fallback to the legacy version for now.
# we fallback to the legacy version for now.
relation
=
relation
=
...
@@ -64,7 +68,7 @@ module Geo
...
@@ -64,7 +68,7 @@ module Geo
end
end
relation
relation
.
limit
(
db_retrieve_
batch_size
)
.
limit
(
batch_size
)
.
pluck
(
:id
,
:uploader
)
.
pluck
(
:id
,
:uploader
)
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
underscore
]
}
.
map
{
|
id
,
uploader
|
[
id
,
uploader
.
sub
(
/Uploader\z/
,
''
).
underscore
]
}
end
end
...
@@ -84,7 +88,6 @@ module Geo
...
@@ -84,7 +88,6 @@ module Geo
Geo
::
Fdw
::
Upload
.
joins
(
"LEFT OUTER JOIN file_registry ON file_registry.file_id =
#{
fdw_table
}
.id AND file_registry.file_type IN (
#{
obj_types
}
)"
)
Geo
::
Fdw
::
Upload
.
joins
(
"LEFT OUTER JOIN file_registry ON file_registry.file_id =
#{
fdw_table
}
.id AND file_registry.file_type IN (
#{
obj_types
}
)"
)
.
where
(
'file_registry.file_id IS NULL'
)
.
where
(
'file_registry.file_id IS NULL'
)
.
order
(
created_at: :desc
)
end
end
def
legacy_find_upload_object_ids
def
legacy_find_upload_object_ids
...
...
app/workers/geo/repository_sync_worker.rb
View file @
fe46d403
...
@@ -13,24 +13,28 @@ module Geo
...
@@ -13,24 +13,28 @@ module Geo
end
end
def
load_pending_resources
def
load_pending_resources
project_ids_not_synced
=
find_project_ids_not_synced
resources
=
find_project_ids_not_synced
(
batch_size:
db_retrieve_batch_size
)
project_ids_updated_recently
=
find_project_ids_updated_recently
remaining_capacity
=
db_retrieve_batch_size
-
resources
.
size
interleave
(
project_ids_not_synced
,
project_ids_updated_recently
)
if
remaining_capacity
.
zero?
resources
else
resources
+
find_project_ids_updated_recently
(
batch_size:
remaining_capacity
)
end
end
end
def
find_project_ids_not_synced
def
find_project_ids_not_synced
(
batch_size
:)
healthy_shards_restriction
(
current_node
.
unsynced_projects
)
healthy_shards_restriction
(
current_node
.
unsynced_projects
)
.
reorder
(
last_repository_updated_at: :desc
)
.
reorder
(
last_repository_updated_at: :desc
)
.
limit
(
db_retrieve_
batch_size
)
.
limit
(
batch_size
)
.
pluck
(
:id
)
.
pluck
(
:id
)
end
end
def
find_project_ids_updated_recently
def
find_project_ids_updated_recently
(
batch_size
:)
current_node
.
project_registries
current_node
.
project_registries
.
dirty
.
dirty
.
order
(
Gitlab
::
Database
.
nulls_first_order
(
:last_repository_synced_at
,
:desc
))
.
order
(
Gitlab
::
Database
.
nulls_first_order
(
:last_repository_synced_at
,
:desc
))
.
limit
(
db_retrieve_
batch_size
)
.
limit
(
batch_size
)
.
pluck
(
:project_id
)
.
pluck
(
:project_id
)
end
end
...
...
changelogs/unreleased-ee/3810-geo-disable-retries.yml
0 → 100644
View file @
fe46d403
---
title
:
'
Geo:
Don'
'
t
retry
repositories
or
files
until
everything
has
been
backfilled'
merge_request
:
3182
author
:
type
:
changed
spec/workers/geo/repository_sync_worker_spec.rb
View file @
fe46d403
...
@@ -101,10 +101,14 @@ describe Geo::RepositorySyncWorker, :postgresql do
...
@@ -101,10 +101,14 @@ describe Geo::RepositorySyncWorker, :postgresql do
let!
(
:project_list
)
{
create_list
(
:project
,
4
,
:random_last_repository_updated_at
)
}
let!
(
:project_list
)
{
create_list
(
:project
,
4
,
:random_last_repository_updated_at
)
}
before
do
before
do
# Neither of these are needed for this spec
unsynced_project
.
destroy
project_in_synced_group
.
destroy
allow_any_instance_of
(
described_class
).
to
receive
(
:db_retrieve_batch_size
).
and_return
(
2
)
# Must be >1 because of the Geo::BaseSchedulerWorker#interleave
allow_any_instance_of
(
described_class
).
to
receive
(
:db_retrieve_batch_size
).
and_return
(
2
)
# Must be >1 because of the Geo::BaseSchedulerWorker#interleave
secondary
.
update!
(
repos_max_capacity:
3
)
# Must be more than db_retrieve_batch_size
secondary
.
update!
(
repos_max_capacity:
3
)
# Must be more than db_retrieve_batch_size
allow_any_instance_of
(
Project
).
to
receive
(
:ensure_repository
).
and_raise
(
Gitlab
::
Shell
::
Error
.
new
(
'foo'
))
allow_any_instance_of
(
Project
).
to
receive
(
:ensure_repository
).
and_raise
(
Gitlab
::
Shell
::
Error
.
new
(
'foo'
))
allow_any_instance_of
(
Geo
::
Project
SyncWorker
).
to
receive
(
:sync_wiki
?
).
and_return
(
false
)
allow_any_instance_of
(
Geo
::
Project
Registry
).
to
receive
(
:wiki_sync_due
?
).
and_return
(
false
)
allow_any_instance_of
(
Geo
::
RepositorySyncService
).
to
receive
(
:expire_repository_caches
)
allow_any_instance_of
(
Geo
::
RepositorySyncService
).
to
receive
(
:expire_repository_caches
)
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