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
31ad927a
Commit
31ad927a
authored
May 02, 2017
by
Douglas Barbosa Alexandre
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Backfill projects where the last attempt to backfill failed
parent
f420cde3
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
87 additions
and
23 deletions
+87
-23
app/services/geo/repository_backfill_service.rb
app/services/geo/repository_backfill_service.rb
+23
-18
app/workers/geo_backfill_worker.rb
app/workers/geo_backfill_worker.rb
+1
-1
spec/services/geo/repository_backfill_service_spec.rb
spec/services/geo/repository_backfill_service_spec.rb
+51
-4
spec/workers/geo/geo_backfill_worker_spec.rb
spec/workers/geo/geo_backfill_worker_spec.rb
+12
-0
No files found.
app/services/geo/repository_backfill_service.rb
View file @
31ad927a
...
@@ -10,7 +10,17 @@ module Geo
...
@@ -10,7 +10,17 @@ module Geo
end
end
def
execute
def
execute
return
if
backfilled?
(
project
)
# When Geo customers upgrade to 9.0, the secondaries nodes that are
# enabled will start the backfilling process automatically. We need
# to populate the tracking database correctly for projects synced
# before the process being started or projects created during the
# backfilling. Otherwise, the query to retrieve the projects will
# always return the same projects because they don't have entries
# in the tracking database
if
backfilled?
update_registry
(
DateTime
.
now
,
DateTime
.
now
)
return
end
try_obtain_lease
do
try_obtain_lease
do
log
(
'Started repository sync'
)
log
(
'Started repository sync'
)
...
@@ -83,32 +93,27 @@ module Geo
...
@@ -83,32 +93,27 @@ module Geo
Gitlab
::
ExclusiveLease
.
cancel
(
lease_key
,
repository_lease
)
Gitlab
::
ExclusiveLease
.
cancel
(
lease_key
,
repository_lease
)
end
end
def
backfilled?
(
project
)
def
backfilled?
return
false
unless
project
.
repository
.
exists?
return
false
unless
project
.
repository
.
exists?
return
false
if
project
.
repository
.
exists?
&&
project
.
repository
.
empty?
return
false
if
project
.
repository
.
exists?
&&
project
.
repository
.
empty?
return
true
if
registry_exists?
(
project
)
return
false
if
failed_registry_exists?
# When Geo customers upgrade to 9.0, the secondaries nodes that are
# enabled will start the backfilling process automatically. We need
# to populate the tracking database correctly for projects synced
# before the process being started or projects created during the
# backfilling. Otherwise, the query to retrieve the projects will
# always return the same projects because they don't have entries
# in the tracking database
update_registry
(
DateTime
.
now
,
DateTime
.
now
)
true
true
end
end
def
registry_exists?
(
project
)
def
failed_registry_exists?
Geo
::
ProjectRegistry
.
where
(
project_id:
project
.
id
)
Geo
::
ProjectRegistry
.
failed
.
where
(
project_id:
project_id
).
any?
.
where
.
not
(
last_repository_synced_at:
nil
)
end
.
any?
def
synced_registry_exists?
Geo
::
ProjectRegistry
.
synced
.
where
(
project_id:
project_id
).
any?
end
end
def
update_registry
(
started_at
,
finished_at
)
def
update_registry
(
started_at
,
finished_at
)
return
if
synced_registry_exists?
log
(
'Updating registry information'
)
log
(
'Updating registry information'
)
registry
=
Geo
::
ProjectRegistry
.
find_or_initialize_by
(
project_id:
project
.
id
)
registry
=
Geo
::
ProjectRegistry
.
find_or_initialize_by
(
project_id:
project
_
id
)
registry
.
last_repository_synced_at
=
started_at
registry
.
last_repository_synced_at
=
started_at
registry
.
last_repository_successful_sync_at
=
finished_at
if
finished_at
registry
.
last_repository_successful_sync_at
=
finished_at
if
finished_at
registry
.
save
registry
.
save
...
@@ -131,7 +136,7 @@ module Geo
...
@@ -131,7 +136,7 @@ module Geo
end
end
def
log
(
message
)
def
log
(
message
)
Rails
.
logger
.
info
"
#{
self
.
class
.
name
}
:
#{
message
}
for project
#{
project
.
path_with_namespace
}
(
#{
project
.
id
}
)"
Rails
.
logger
.
info
(
"
#{
self
.
class
.
name
}
:
#{
message
}
for project
#{
project
.
path_with_namespace
}
(
#{
project
.
id
}
)"
)
end
end
end
end
end
end
app/workers/geo_backfill_worker.rb
View file @
31ad927a
...
@@ -39,7 +39,7 @@ class GeoBackfillWorker
...
@@ -39,7 +39,7 @@ class GeoBackfillWorker
private
private
def
find_project_ids
def
find_project_ids
Project
.
where
.
not
(
id:
Geo
::
ProjectRegistry
.
pluck
(
:project_id
))
Project
.
where
.
not
(
id:
Geo
::
ProjectRegistry
.
synced
.
pluck
(
:project_id
))
.
limit
(
BATCH_SIZE
)
.
limit
(
BATCH_SIZE
)
.
pluck
(
:id
)
.
pluck
(
:id
)
end
end
...
...
spec/services/geo/repository_backfill_service_spec.rb
View file @
31ad927a
...
@@ -80,14 +80,15 @@ describe Geo::RepositoryBackfillService, services: true do
...
@@ -80,14 +80,15 @@ describe Geo::RepositoryBackfillService, services: true do
end
end
end
end
context
'when repository was backfilled'
do
context
'when repository was backfilled
successfully
'
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:last_repository_successful_sync_at
)
{
5
.
days
.
ago
}
let!
(
:registry
)
do
let!
(
:registry
)
do
Geo
::
ProjectRegistry
.
create
(
Geo
::
ProjectRegistry
.
create
(
project:
project
,
project:
project
,
last_repository_synced_at:
DateTime
.
now
,
last_repository_synced_at:
5
.
days
.
ago
,
last_repository_successful_sync_at:
DateTime
.
now
last_repository_successful_sync_at:
last_repository_successful_sync_at
)
)
end
end
...
@@ -98,9 +99,55 @@ describe Geo::RepositoryBackfillService, services: true do
...
@@ -98,9 +99,55 @@ describe Geo::RepositoryBackfillService, services: true do
end
end
context
'tracking database'
do
context
'tracking database'
do
it
'does not
track repository sync
'
do
it
'does not
create a new registry
'
do
expect
{
subject
.
execute
}.
not_to
change
(
Geo
::
ProjectRegistry
,
:count
)
expect
{
subject
.
execute
}.
not_to
change
(
Geo
::
ProjectRegistry
,
:count
)
end
end
it
'does not update last_repository_successful_sync_at'
do
subject
.
execute
expect
(
registry
.
reload
.
last_repository_successful_sync_at
).
to
eq
last_repository_successful_sync_at
end
end
end
context
'when last attempt to backfill the repository failed'
do
let
(
:project
)
{
create
(
:project
)
}
let!
(
:registry
)
do
Geo
::
ProjectRegistry
.
create
(
project:
project
,
last_repository_synced_at:
DateTime
.
now
,
last_repository_successful_sync_at:
nil
)
end
it
'fetches project repositories'
do
fetch_count
=
0
allow_any_instance_of
(
Repository
).
to
receive
(
:fetch_geo_mirror
)
do
fetch_count
+=
1
end
subject
.
execute
expect
(
fetch_count
).
to
eq
2
end
context
'tracking database'
do
before
do
allow_any_instance_of
(
Repository
).
to
receive
(
:fetch_geo_mirror
)
{
true
}
end
it
'does not create a new registry'
do
expect
{
subject
.
execute
}.
not_to
change
(
Geo
::
ProjectRegistry
,
:count
)
end
it
'updates last_repository_successful_sync_at'
do
subject
.
execute
expect
(
registry
.
reload
.
last_repository_successful_sync_at
).
not_to
be_nil
end
end
end
end
end
end
end
...
...
spec/workers/geo/geo_backfill_worker_spec.rb
View file @
31ad927a
...
@@ -18,6 +18,18 @@ describe Geo::GeoBackfillWorker, services: true do
...
@@ -18,6 +18,18 @@ describe Geo::GeoBackfillWorker, services: true do
subject
.
perform
subject
.
perform
end
end
it
'performs Geo::RepositoryBackfillService for projects where last attempt to backfill failed'
do
Geo
::
ProjectRegistry
.
create
(
project:
Project
.
first
,
last_repository_synced_at:
DateTime
.
now
,
last_repository_successful_sync_at:
nil
)
expect
(
Geo
::
RepositoryBackfillService
).
to
receive
(
:new
).
twice
.
and_return
(
spy
)
subject
.
perform
end
it
'does not perform Geo::RepositoryBackfillService when tracking DB is not available'
do
it
'does not perform Geo::RepositoryBackfillService when tracking DB is not available'
do
allow
(
Rails
.
configuration
).
to
receive
(
:respond_to?
).
with
(
:geo_database
)
{
false
}
allow
(
Rails
.
configuration
).
to
receive
(
:respond_to?
).
with
(
:geo_database
)
{
false
}
...
...
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