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
7409185b
Commit
7409185b
authored
Jun 03, 2021
by
Thong Kuah
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move overridden Load Balancing calls in Peek to Core
parent
ecb4ee16
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
148 additions
and
255 deletions
+148
-255
app/models/postgresql/replication_slot.rb
app/models/postgresql/replication_slot.rb
+1
-1
ee/lib/ee/peek/views/active_record.rb
ee/lib/ee/peek/views/active_record.rb
+0
-34
ee/spec/lib/peek/views/active_record_spec.rb
ee/spec/lib/peek/views/active_record_spec.rb
+0
-173
lib/peek/views/active_record.rb
lib/peek/views/active_record.rb
+16
-3
spec/lib/peek/views/active_record_spec.rb
spec/lib/peek/views/active_record_spec.rb
+131
-44
No files found.
app/models/postgresql/replication_slot.rb
View file @
7409185b
...
@@ -26,7 +26,7 @@ module Postgresql
...
@@ -26,7 +26,7 @@ module Postgresql
"(pg_current_wal_insert_lsn(), restart_lsn)::bigint"
"(pg_current_wal_insert_lsn(), restart_lsn)::bigint"
# We force the use of a transaction here so the query always goes to the
# We force the use of a transaction here so the query always goes to the
# primary, even when using the
EE
DB load balancer.
# primary, even when using the DB load balancer.
sizes
=
transaction
{
pluck
(
Arel
.
sql
(
lag_function
))
}
sizes
=
transaction
{
pluck
(
Arel
.
sql
(
lag_function
))
}
too_great
=
sizes
.
compact
.
count
{
|
size
|
size
>=
max
}
too_great
=
sizes
.
compact
.
count
{
|
size
|
size
>=
max
}
...
...
ee/lib/ee/peek/views/active_record.rb
deleted
100644 → 0
View file @
ecb4ee16
# frozen_string_literal: true
module
EE
module
Peek
module
Views
module
ActiveRecord
extend
::
Gitlab
::
Utils
::
Override
override
:generate_detail
def
generate_detail
(
start
,
finish
,
data
)
detail
=
super
if
::
Gitlab
::
Database
::
LoadBalancing
.
enable?
role
=
::
Gitlab
::
Database
::
LoadBalancing
.
db_role_for_connection
(
data
[
:connection
])
||
::
Gitlab
::
Database
::
LoadBalancing
::
ROLE_UNKNOWN
detail
[
:db_role
]
=
role
.
to_s
.
capitalize
end
detail
end
override
:count_summary
def
count_summary
(
item
,
count
)
super
if
::
Gitlab
::
Database
::
LoadBalancing
.
enable?
count
[
item
[
:db_role
]]
||=
0
count
[
item
[
:db_role
]]
+=
1
end
end
end
end
end
end
ee/spec/lib/peek/views/active_record_spec.rb
deleted
100644 → 0
View file @
ecb4ee16
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Peek
::
Views
::
ActiveRecord
,
:request_store
do
subject
{
Peek
.
views
.
find
{
|
v
|
v
.
instance_of?
(
Peek
::
Views
::
ActiveRecord
)
}
}
let
(
:connection_replica
)
{
double
(
:connection_replica
)
}
let
(
:connection_primary_1
)
{
double
(
:connection_primary
)
}
let
(
:connection_primary_2
)
{
double
(
:connection_primary
)
}
let
(
:connection_unknown
)
{
double
(
:connection_unknown
)
}
let
(
:event_1
)
do
{
name:
'SQL'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
cached:
false
,
connection:
connection_primary_1
}
end
let
(
:event_2
)
do
{
name:
'SQL'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
cached:
true
,
connection:
connection_replica
}
end
let
(
:event_3
)
do
{
name:
'SQL'
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
,
cached:
false
,
connection:
connection_primary_2
}
end
let
(
:event_4
)
do
{
name:
'SCHEMA'
,
sql:
'SELECT VERSION()'
,
cached:
false
,
connection:
connection_unknown
}
end
before
do
allow
(
Gitlab
::
PerformanceBar
).
to
receive
(
:enabled_for_request?
).
and_return
(
true
)
allow
(
connection_replica
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_primary_1
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_primary_2
).
to
receive
(
:transaction_open?
).
and_return
(
true
)
allow
(
connection_unknown
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
end
context
'when database load balancing is not enabled'
do
it
'subscribes and store data into peek views'
do
Timecop
.
freeze
(
2021
,
2
,
23
,
10
,
0
)
do
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
1
.
second
,
'1'
,
event_1
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
2
.
seconds
,
'2'
,
event_2
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
3
.
seconds
,
'3'
,
event_3
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
4
.
seconds
,
'4'
,
event_4
)
end
expect
(
subject
.
results
).
to
match
(
calls:
4
,
summary:
{
"Cached"
=>
1
,
"In a transaction"
=>
1
},
duration:
'10000.00ms'
,
warnings:
[
"active-record duration: 10000.0 over 3000"
],
details:
contain_exactly
(
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
1000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
'Cached'
,
transaction:
''
,
duration:
2000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
'In a transaction'
,
duration:
3000.0
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
4000.0
,
sql:
'SELECT VERSION()'
)
)
)
end
end
context
'when database load balancing is enabled'
do
before
do
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:enable?
).
and_return
(
true
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_replica
).
and_return
(
:replica
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_primary_1
).
and_return
(
:primary
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_primary_2
).
and_return
(
:primary
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_unknown
).
and_return
(
nil
)
end
it
'includes db role data'
do
Timecop
.
freeze
(
2021
,
2
,
23
,
10
,
0
)
do
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
1
.
second
,
'1'
,
event_1
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
2
.
seconds
,
'2'
,
event_2
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
3
.
seconds
,
'3'
,
event_3
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
4
.
seconds
,
'4'
,
event_4
)
end
expect
(
subject
.
results
).
to
match
(
calls:
4
,
summary:
{
"Cached"
=>
1
,
"In a transaction"
=>
1
,
"Primary"
=>
2
,
"Replica"
=>
1
,
"Unknown"
=>
1
},
duration:
'10000.00ms'
,
warnings:
[
"active-record duration: 10000.0 over 3000"
],
details:
contain_exactly
(
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
1000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
,
db_role:
'Primary'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
'Cached'
,
transaction:
''
,
duration:
2000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
,
db_role:
'Replica'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
'In a transaction'
,
duration:
3000.0
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
,
db_role:
'Primary'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
4000.0
,
sql:
'SELECT VERSION()'
,
db_role:
'Unknown'
)
)
)
end
end
end
lib/peek/views/active_record.rb
View file @
7409185b
...
@@ -43,6 +43,11 @@ module Peek
...
@@ -43,6 +43,11 @@ module Peek
count
[
item
[
:transaction
]]
||=
0
count
[
item
[
:transaction
]]
||=
0
count
[
item
[
:transaction
]]
+=
1
count
[
item
[
:transaction
]]
+=
1
end
end
if
::
Gitlab
::
Database
::
LoadBalancing
.
enable?
count
[
item
[
:db_role
]]
||=
0
count
[
item
[
:db_role
]]
+=
1
end
end
end
def
setup_subscribers
def
setup_subscribers
...
@@ -60,11 +65,19 @@ module Peek
...
@@ -60,11 +65,19 @@ module Peek
sql:
data
[
:sql
].
strip
,
sql:
data
[
:sql
].
strip
,
backtrace:
Gitlab
::
BacktraceCleaner
.
clean_backtrace
(
caller
),
backtrace:
Gitlab
::
BacktraceCleaner
.
clean_backtrace
(
caller
),
cached:
data
[
:cached
]
?
'Cached'
:
''
,
cached:
data
[
:cached
]
?
'Cached'
:
''
,
transaction:
data
[
:connection
].
transaction_open?
?
'In a transaction'
:
''
transaction:
data
[
:connection
].
transaction_open?
?
'In a transaction'
:
''
,
db_role:
db_role
(
data
)
}
}
end
end
def
db_role
(
data
)
return
unless
::
Gitlab
::
Database
::
LoadBalancing
.
enable?
role
=
::
Gitlab
::
Database
::
LoadBalancing
.
db_role_for_connection
(
data
[
:connection
])
||
::
Gitlab
::
Database
::
LoadBalancing
::
ROLE_UNKNOWN
role
.
to_s
.
capitalize
end
end
end
end
end
end
end
Peek
::
Views
::
ActiveRecord
.
prepend_mod_with
(
'Peek::Views::ActiveRecord'
)
spec/lib/peek/views/active_record_spec.rb
View file @
7409185b
...
@@ -5,16 +5,17 @@ require 'spec_helper'
...
@@ -5,16 +5,17 @@ require 'spec_helper'
RSpec
.
describe
Peek
::
Views
::
ActiveRecord
,
:request_store
do
RSpec
.
describe
Peek
::
Views
::
ActiveRecord
,
:request_store
do
subject
{
Peek
.
views
.
find
{
|
v
|
v
.
instance_of?
(
Peek
::
Views
::
ActiveRecord
)
}
}
subject
{
Peek
.
views
.
find
{
|
v
|
v
.
instance_of?
(
Peek
::
Views
::
ActiveRecord
)
}
}
let
(
:connection_1
)
{
double
(
:connection
)
}
let
(
:connection_replica
)
{
double
(
:connection_replica
)
}
let
(
:connection_2
)
{
double
(
:connection
)
}
let
(
:connection_primary_1
)
{
double
(
:connection_primary
)
}
let
(
:connection_3
)
{
double
(
:connection
)
}
let
(
:connection_primary_2
)
{
double
(
:connection_primary
)
}
let
(
:connection_unknown
)
{
double
(
:connection_unknown
)
}
let
(
:event_1
)
do
let
(
:event_1
)
do
{
{
name:
'SQL'
,
name:
'SQL'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
cached:
false
,
cached:
false
,
connection:
connection_1
connection:
connection_
primary_
1
}
}
end
end
...
@@ -23,7 +24,7 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
...
@@ -23,7 +24,7 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
name:
'SQL'
,
name:
'SQL'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
sql:
'SELECT * FROM users WHERE id = 10'
,
cached:
true
,
cached:
true
,
connection:
connection_
2
connection:
connection_
replica
}
}
end
end
...
@@ -32,32 +33,44 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
...
@@ -32,32 +33,44 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
name:
'SQL'
,
name:
'SQL'
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
,
cached:
false
,
cached:
false
,
connection:
connection_3
connection:
connection_primary_2
}
end
let
(
:event_4
)
do
{
name:
'SCHEMA'
,
sql:
'SELECT VERSION()'
,
cached:
false
,
connection:
connection_unknown
}
}
end
end
before
do
before
do
allow
(
Gitlab
::
PerformanceBar
).
to
receive
(
:enabled_for_request?
).
and_return
(
true
)
allow
(
Gitlab
::
PerformanceBar
).
to
receive
(
:enabled_for_request?
).
and_return
(
true
)
allow
(
connection_1
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_replica
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_2
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_primary_1
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
allow
(
connection_3
).
to
receive
(
:transaction_open?
).
and_return
(
true
)
allow
(
connection_primary_2
).
to
receive
(
:transaction_open?
).
and_return
(
true
)
allow
(
connection_unknown
).
to
receive
(
:transaction_open?
).
and_return
(
false
)
end
end
context
'when database load balancing is not enabled'
do
it
'subscribes and store data into peek views'
do
it
'subscribes and store data into peek views'
do
Timecop
.
freeze
(
2021
,
2
,
23
,
10
,
0
)
do
Timecop
.
freeze
(
2021
,
2
,
23
,
10
,
0
)
do
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
1
.
second
,
'1'
,
event_1
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
1
.
second
,
'1'
,
event_1
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
2
.
seconds
,
'2'
,
event_2
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
2
.
seconds
,
'2'
,
event_2
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
3
.
seconds
,
'3'
,
event_3
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
3
.
seconds
,
'3'
,
event_3
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
4
.
seconds
,
'4'
,
event_4
)
end
end
expect
(
subject
.
results
).
to
match
(
expect
(
subject
.
results
).
to
match
(
calls:
3
,
calls:
4
,
summary:
{
summary:
{
"Cached"
=>
1
,
"Cached"
=>
1
,
"In a transaction"
=>
1
"In a transaction"
=>
1
},
},
duration:
'6
000.00ms'
,
duration:
'10
000.00ms'
,
warnings:
[
"active-record duration: 6
000.0 over 3000"
],
warnings:
[
"active-record duration: 10
000.0 over 3000"
],
details:
contain_exactly
(
details:
contain_exactly
(
a_hash_including
(
a_hash_including
(
start:
be_a
(
Time
),
start:
be_a
(
Time
),
...
@@ -79,8 +92,82 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
...
@@ -79,8 +92,82 @@ RSpec.describe Peek::Views::ActiveRecord, :request_store do
transaction:
'In a transaction'
,
transaction:
'In a transaction'
,
duration:
3000.0
,
duration:
3000.0
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
sql:
'UPDATE users SET admin = true WHERE id = 10'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
4000.0
,
sql:
'SELECT VERSION()'
)
)
)
end
end
context
'when database load balancing is enabled'
do
before
do
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:enable?
).
and_return
(
true
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_replica
).
and_return
(
:replica
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_primary_1
).
and_return
(
:primary
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_primary_2
).
and_return
(
:primary
)
allow
(
Gitlab
::
Database
::
LoadBalancing
).
to
receive
(
:db_role_for_connection
).
with
(
connection_unknown
).
and_return
(
nil
)
end
it
'includes db role data'
do
Timecop
.
freeze
(
2021
,
2
,
23
,
10
,
0
)
do
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
1
.
second
,
'1'
,
event_1
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
2
.
seconds
,
'2'
,
event_2
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
3
.
seconds
,
'3'
,
event_3
)
ActiveSupport
::
Notifications
.
publish
(
'sql.active_record'
,
Time
.
current
,
Time
.
current
+
4
.
seconds
,
'4'
,
event_4
)
end
expect
(
subject
.
results
).
to
match
(
calls:
4
,
summary:
{
"Cached"
=>
1
,
"In a transaction"
=>
1
,
"Primary"
=>
2
,
"Replica"
=>
1
,
"Unknown"
=>
1
},
duration:
'10000.00ms'
,
warnings:
[
"active-record duration: 10000.0 over 3000"
],
details:
contain_exactly
(
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
1000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
,
db_role:
'Primary'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
'Cached'
,
transaction:
''
,
duration:
2000.0
,
sql:
'SELECT * FROM users WHERE id = 10'
,
db_role:
'Replica'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
'In a transaction'
,
duration:
3000.0
,
sql:
'UPDATE users SET admin = true WHERE id = 10'
,
db_role:
'Primary'
),
a_hash_including
(
start:
be_a
(
Time
),
cached:
''
,
transaction:
''
,
duration:
4000.0
,
sql:
'SELECT VERSION()'
,
db_role:
'Unknown'
)
)
)
)
)
)
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