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
44f055b8
Commit
44f055b8
authored
Mar 31, 2021
by
Quang-Minh Nguyen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove db role being fallbacked to primary
Issue
https://gitlab.com/gitlab-com/gl-infra/scalability/-/issues/965
parent
a4d05d06
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
61 additions
and
3 deletions
+61
-3
ee/lib/ee/gitlab/metrics/subscribers/active_record.rb
ee/lib/ee/gitlab/metrics/subscribers/active_record.rb
+2
-0
ee/lib/gitlab/database/load_balancing.rb
ee/lib/gitlab/database/load_balancing.rb
+1
-1
ee/spec/lib/gitlab/database/load_balancing_spec.rb
ee/spec/lib/gitlab/database/load_balancing_spec.rb
+58
-2
No files found.
ee/lib/ee/gitlab/metrics/subscribers/active_record.rb
View file @
44f055b8
...
@@ -47,6 +47,8 @@ module EE
...
@@ -47,6 +47,8 @@ module EE
return
if
ignored_query?
(
payload
)
return
if
ignored_query?
(
payload
)
db_role
=
::
Gitlab
::
Database
::
LoadBalancing
.
db_role_for_connection
(
payload
[
:connection
])
db_role
=
::
Gitlab
::
Database
::
LoadBalancing
.
db_role_for_connection
(
payload
[
:connection
])
return
if
db_role
.
blank?
increment_db_role_counters
(
db_role
,
payload
)
increment_db_role_counters
(
db_role
,
payload
)
observe_db_role_duration
(
db_role
,
event
)
observe_db_role_duration
(
db_role
,
event
)
end
end
...
...
ee/lib/gitlab/database/load_balancing.rb
View file @
44f055b8
...
@@ -155,7 +155,7 @@ module Gitlab
...
@@ -155,7 +155,7 @@ module Gitlab
def
self
.
db_role_for_connection
(
connection
)
def
self
.
db_role_for_connection
(
connection
)
return
ROLE_PRIMARY
if
!
enable?
||
@proxy
.
blank?
return
ROLE_PRIMARY
if
!
enable?
||
@proxy
.
blank?
proxy
.
load_balancer
.
db_role_for_connection
(
connection
)
||
ROLE_PRIMARY
proxy
.
load_balancer
.
db_role_for_connection
(
connection
)
end
end
end
end
end
end
...
...
ee/spec/lib/gitlab/database/load_balancing_spec.rb
View file @
44f055b8
...
@@ -399,10 +399,10 @@ RSpec.describe Gitlab::Database::LoadBalancing do
...
@@ -399,10 +399,10 @@ RSpec.describe Gitlab::Database::LoadBalancing do
end
end
context
'when the load balancer returns nil'
do
context
'when the load balancer returns nil'
do
it
'returns
:primary
'
do
it
'returns
nil
'
do
allow
(
load_balancer
).
to
receive
(
:db_role_for_connection
).
and_return
(
nil
)
allow
(
load_balancer
).
to
receive
(
:db_role_for_connection
).
and_return
(
nil
)
expect
(
described_class
.
db_role_for_connection
(
connection
)).
to
be
(
:primary
)
expect
(
described_class
.
db_role_for_connection
(
connection
)).
to
be
(
nil
)
expect
(
load_balancer
).
to
have_received
(
:db_role_for_connection
).
with
(
connection
)
expect
(
load_balancer
).
to
have_received
(
:db_role_for_connection
).
with
(
connection
)
end
end
...
@@ -702,6 +702,62 @@ RSpec.describe Gitlab::Database::LoadBalancing do
...
@@ -702,6 +702,62 @@ RSpec.describe Gitlab::Database::LoadBalancing do
end
end
end
end
context
'custom connection handling'
do
where
(
:queries
,
:expected_role
)
do
[
# Reload cache. The schema loading queries should be handled by
# primary.
[
->
{
model
.
connection
.
clear_cache!
model
.
connection
.
schema_cache
.
add
(
'users'
)
model
.
connection
.
pool
.
release_connection
},
:primary
],
# Call model's connection method
[
->
{
connection
=
model
.
connection
connection
.
select_one
(
'SELECT 1'
)
connection
.
pool
.
release_connection
},
:replica
],
# Retrieve connection via #retrieve_connection
[
->
{
connection
=
model
.
retrieve_connection
connection
.
select_one
(
'SELECT 1'
)
connection
.
pool
.
release_connection
},
:primary
]
]
end
with_them
do
include_context
'LoadBalancing setup'
it
'redirects queries to the right roles'
do
roles
=
[]
subscriber
=
ActiveSupport
::
Notifications
.
subscribe
(
'sql.active_record'
)
do
|
event
|
role
=
::
Gitlab
::
Database
::
LoadBalancing
.
db_role_for_connection
(
event
.
payload
[
:connection
])
roles
<<
role
if
role
.
present?
end
self
.
instance_exec
(
&
queries
)
expect
(
roles
).
to
all
(
eql
(
expected_role
))
ensure
ActiveSupport
::
Notifications
.
unsubscribe
(
subscriber
)
if
subscriber
end
end
end
context
'a write inside a transaction inside use_replica_if_possible block'
do
context
'a write inside a transaction inside use_replica_if_possible block'
do
include_context
'LoadBalancing setup'
include_context
'LoadBalancing setup'
...
...
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