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
cce4f6df
Commit
cce4f6df
authored
Nov 16, 2017
by
Douglas Barbosa Alexandre
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Geo - Clean up deleted repositories in a secondary node
parent
9c66889c
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
0 deletions
+53
-0
ee/app/services/ee/projects/destroy_service.rb
ee/app/services/ee/projects/destroy_service.rb
+29
-0
spec/services/geo/repository_destroy_service_spec.rb
spec/services/geo/repository_destroy_service_spec.rb
+24
-0
No files found.
ee/app/services/ee/projects/destroy_service.rb
View file @
cce4f6df
...
@@ -33,17 +33,46 @@ module EE
...
@@ -33,17 +33,46 @@ module EE
# There is no need to do any database operation as it will be
# There is no need to do any database operation as it will be
# replicated by itself.
# replicated by itself.
def
geo_replicate
def
geo_replicate
return
unless
::
Gitlab
::
Geo
.
secondary?
# Flush the cache for both repositories. This has to be done _before_
# Flush the cache for both repositories. This has to be done _before_
# removing the physical repositories as some expiration code depends on
# removing the physical repositories as some expiration code depends on
# Git data (e.g. a list of branch names).
# Git data (e.g. a list of branch names).
flush_caches
(
project
)
flush_caches
(
project
)
trash_repositories!
trash_repositories!
trash_repositories_cleanup!
log_info
(
"Project
\"
#{
project
.
name
}
\"
was removed"
)
log_info
(
"Project
\"
#{
project
.
name
}
\"
was removed"
)
end
end
private
private
# When we remove project we move the repository to path+deleted.git
# then outside the transaction we schedule removal of path+deleted
# with Sidekiq through the after_commit callback. In a Geo secondary
# node we don't have access to the original model anymore then we
# rebuild a Geo::DeletedProject model. Since this model is read-only,
# this callback will not be triggered letting us with stalled
# repositories on disk.
def
trash_repositories_cleanup!
repo_removed_path
=
removal_path
(
repo_path
)
if
gitlab_shell
.
exists?
(
repository_storage_path
,
repo_removed_path
+
'.git'
)
GitlabShellWorker
.
perform_in
(
5
.
minutes
,
:remove_repository
,
repository_storage_path
,
repo_removed_path
)
end
wiki_removed_path
=
removal_path
(
wiki_path
)
if
gitlab_shell
.
exists?
(
repository_storage_path
,
wiki_removed_path
+
'.git'
)
GitlabShellWorker
.
perform_in
(
5
.
minutes
,
:remove_repository
,
repository_storage_path
,
wiki_removed_path
)
end
end
def
repository_storage_path
project
.
repository_storage_path
end
def
log_audit_event
(
project
)
def
log_audit_event
(
project
)
::
AuditEventService
.
new
(
::
AuditEventService
.
new
(
current_user
,
current_user
,
...
...
spec/services/geo/repository_destroy_service_spec.rb
View file @
cce4f6df
require
'spec_helper'
require
'spec_helper'
describe
Geo
::
RepositoryDestroyService
do
describe
Geo
::
RepositoryDestroyService
do
set
(
:secondary
)
{
create
(
:geo_node
)
}
let
(
:project
)
{
create
(
:project_empty_repo
)
}
let
(
:project
)
{
create
(
:project_empty_repo
)
}
subject
(
:service
)
{
described_class
.
new
(
project
.
id
,
project
.
name
,
project
.
disk_path
,
project
.
repository_storage
)
}
subject
(
:service
)
{
described_class
.
new
(
project
.
id
,
project
.
name
,
project
.
disk_path
,
project
.
repository_storage
)
}
before
do
allow
(
Gitlab
::
Geo
).
to
receive
(
:current_node
)
{
secondary
}
end
describe
'#async_execute'
do
describe
'#async_execute'
do
it
'starts the worker'
do
it
'starts the worker'
do
expect
(
GeoRepositoryDestroyWorker
).
to
receive
(
:perform_async
)
expect
(
GeoRepositoryDestroyWorker
).
to
receive
(
:perform_async
)
...
@@ -29,6 +35,15 @@ describe Geo::RepositoryDestroyService do
...
@@ -29,6 +35,15 @@ describe Geo::RepositoryDestroyService do
expect
(
project
.
gitlab_shell
.
exists?
(
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
.git"
)).
to
be_falsey
expect
(
project
.
gitlab_shell
.
exists?
(
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
.git"
)).
to
be_falsey
end
end
it
'cleans up deleted repositories'
do
project
.
delete
expect
(
::
GitlabShellWorker
).
to
receive
(
:perform_in
)
.
with
(
5
.
minutes
,
:remove_repository
,
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
+
#{
project
.
id
}
+deleted"
)
service
.
execute
end
end
end
context
'hashed storage project'
do
context
'hashed storage project'
do
...
@@ -43,6 +58,15 @@ describe Geo::RepositoryDestroyService do
...
@@ -43,6 +58,15 @@ describe Geo::RepositoryDestroyService do
expect
(
project
.
gitlab_shell
.
exists?
(
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
.git"
)).
to
be_falsey
expect
(
project
.
gitlab_shell
.
exists?
(
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
.git"
)).
to
be_falsey
end
end
it
'cleans up deleted repositories'
do
project
.
delete
expect
(
::
GitlabShellWorker
).
to
receive
(
:perform_in
)
.
with
(
5
.
minutes
,
:remove_repository
,
project
.
repository_storage_path
,
"
#{
project
.
disk_path
}
+
#{
project
.
id
}
+deleted"
)
service
.
execute
end
end
end
end
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