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
40ecff12
Commit
40ecff12
authored
Aug 01, 2018
by
Gabriel Mazetto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve FDW performance with a workaround
parent
181e84e3
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
18 additions
and
11 deletions
+18
-11
ee/app/controllers/admin/geo_projects_controller.rb
ee/app/controllers/admin/geo_projects_controller.rb
+5
-1
ee/app/finders/geo/project_registry_status_finder.rb
ee/app/finders/geo/project_registry_status_finder.rb
+10
-3
ee/spec/finders/geo/project_registry_status_finder_spec.rb
ee/spec/finders/geo/project_registry_status_finder_spec.rb
+3
-7
No files found.
ee/app/controllers/admin/geo_projects_controller.rb
View file @
40ecff12
...
@@ -11,7 +11,11 @@ class Admin::GeoProjectsController < Admin::ApplicationController
...
@@ -11,7 +11,11 @@ class Admin::GeoProjectsController < Admin::ApplicationController
case
params
[
:sync_status
]
case
params
[
:sync_status
]
when
'never'
when
'never'
@projects
=
finder
.
never_synced_projects
.
page
(
params
[
:page
])
# This method uses FDW heavily and due to optimizations we need to inject the pagination
# earlier as well, so we need the block to do that
@projects
=
finder
.
never_synced_projects
do
|
fdw_relation
|
fdw_relation
.
page
(
params
[
:page
])
end
.
page
(
params
[
:page
])
when
'failed'
when
'failed'
@registries
=
finder
.
failed_projects
.
page
(
params
[
:page
])
@registries
=
finder
.
failed_projects
.
page
(
params
[
:page
])
when
'pending'
when
'pending'
...
...
ee/app/finders/geo/project_registry_status_finder.rb
View file @
40ecff12
...
@@ -63,16 +63,23 @@ module Geo
...
@@ -63,16 +63,23 @@ module Geo
# We include here both projects without a corresponding ProjectRegistry
# We include here both projects without a corresponding ProjectRegistry
# or projects that have never successfully synced.
# or projects that have never successfully synced.
#
#
# @yield [ActiveRecord::Relation]
# @return [Geo::Fdw::Project] Projects that has never been fully synced
# @return [Geo::Fdw::Project] Projects that has never been fully synced
def
never_synced_projects
def
never_synced_projects
no_project_registry
=
project_registry
[
:project_id
].
eq
(
nil
)
no_project_registry
=
project_registry
[
:project_id
].
eq
(
nil
)
no_repository_synced
=
project_registry
[
:last_repository_successful_sync_at
].
eq
(
nil
)
no_repository_synced
=
project_registry
[
:last_repository_successful_sync_at
].
eq
(
nil
)
Geo
::
Fdw
::
Project
.
joins
(
"LEFT OUTER JOIN project_registry ON (project_registry.project_id =
#{
Geo
::
Fdw
::
Project
.
table_name
}
.id)"
)
project_ids
=
Geo
::
Fdw
::
Project
.
select
(
:id
)
.
joins
(
"LEFT OUTER JOIN project_registry ON (project_registry.project_id =
#{
Geo
::
Fdw
::
Project
.
table_name
}
.id)"
)
.
where
(
.
where
(
no_project_registry
no_project_registry
.
or
(
no_repository_synced
)
.
or
(
no_repository_synced
))
).
includes
(
:project_registry
)
# This allows us to inject pagination
if
block_given?
project_ids
=
yield
(
project_ids
)
end
Project
.
where
(
id:
project_ids
.
to_a
).
includes
(
:project_registry
)
end
end
private
private
...
...
ee/spec/finders/geo/project_registry_status_finder_spec.rb
View file @
40ecff12
...
@@ -62,16 +62,12 @@ describe Geo::ProjectRegistryStatusFinder, :geo do
...
@@ -62,16 +62,12 @@ describe Geo::ProjectRegistryStatusFinder, :geo do
describe
'#never_synced_projects'
do
describe
'#never_synced_projects'
do
it
'returns only FDW projects without registry or with never synced registries'
do
it
'returns only FDW projects without registry or with never synced registries'
do
fdw_project_with_never_synced_registry_with_failure
=
Geo
::
Fdw
::
Project
.
find
(
never_synced_registry_with_failure
.
project
.
id
)
fdw_project_with_never_synced_registry
=
Geo
::
Fdw
::
Project
.
find
(
project_with_never_synced_registry
.
id
)
fdw_project_without_registry
=
Geo
::
Fdw
::
Project
.
find
(
project_without_registry
.
id
)
result
=
subject
.
never_synced_projects
result
=
subject
.
never_synced_projects
expect
(
result
).
to
contain_exactly
(
expect
(
result
).
to
contain_exactly
(
fdw_
project_without_registry
,
project_without_registry
,
fdw_
project_with_never_synced_registry
,
project_with_never_synced_registry
,
fdw_project_with_never_synced_registry_with_failure
never_synced_registry_with_failure
.
project
)
)
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