Commit 8d97cfde authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab-ce master

parents 1044ffb5 7064d48e
...@@ -16,7 +16,7 @@ gem 'sprockets', '~> 3.7.0' ...@@ -16,7 +16,7 @@ gem 'sprockets', '~> 3.7.0'
gem 'default_value_for', '~> 3.2.0' gem 'default_value_for', '~> 3.2.0'
# Supported DBs # Supported DBs
gem 'pg', '~> 1.1', group: :postgres gem 'pg', '~> 1.1'
gem 'rugged', '~> 0.28' gem 'rugged', '~> 0.28'
gem 'grape-path-helpers', '~> 1.1' gem 'grape-path-helpers', '~> 1.1'
...@@ -309,7 +309,6 @@ gem 'batch-loader', '~> 1.4.0' ...@@ -309,7 +309,6 @@ gem 'batch-loader', '~> 1.4.0'
# Perf bar # Perf bar
gem 'peek', '~> 1.0.1' gem 'peek', '~> 1.0.1'
gem 'peek-gc', '~> 0.0.2' gem 'peek-gc', '~> 0.0.2'
gem 'peek-pg', '~> 1.3.0', group: :postgres
gem 'peek-rblineprof', '~> 0.2.0' gem 'peek-rblineprof', '~> 0.2.0'
# Snowplow events tracking # Snowplow events tracking
......
...@@ -674,11 +674,6 @@ GEM ...@@ -674,11 +674,6 @@ GEM
railties (>= 4.0.0) railties (>= 4.0.0)
peek-gc (0.0.2) peek-gc (0.0.2)
peek peek
peek-pg (1.3.0)
concurrent-ruby
concurrent-ruby-ext
peek
pg
peek-rblineprof (0.2.0) peek-rblineprof (0.2.0)
peek peek
rblineprof rblineprof
...@@ -1226,7 +1221,6 @@ DEPENDENCIES ...@@ -1226,7 +1221,6 @@ DEPENDENCIES
org-ruby (~> 0.9.12) org-ruby (~> 0.9.12)
peek (~> 1.0.1) peek (~> 1.0.1)
peek-gc (~> 0.0.2) peek-gc (~> 0.0.2)
peek-pg (~> 1.3.0)
peek-rblineprof (~> 0.2.0) peek-rblineprof (~> 0.2.0)
pg (~> 1.1) pg (~> 1.1)
premailer-rails (~> 1.9.7) premailer-rails (~> 1.9.7)
......
...@@ -16,11 +16,14 @@ export default { ...@@ -16,11 +16,14 @@ export default {
type: String, type: String,
required: true, required: true,
}, },
header: { title: {
type: String, type: String,
required: true, required: false,
default() {
return this.metric;
},
}, },
details: { header: {
type: String, type: String,
required: true, required: true,
}, },
...@@ -34,7 +37,7 @@ export default { ...@@ -34,7 +37,7 @@ export default {
return this.currentRequest.details[this.metric]; return this.currentRequest.details[this.metric];
}, },
detailsList() { detailsList() {
return this.metricDetails[this.details]; return this.metricDetails.details;
}, },
}, },
}; };
...@@ -101,6 +104,6 @@ export default { ...@@ -101,6 +104,6 @@ export default {
<div slot="footer"></div> <div slot="footer"></div>
</gl-modal> </gl-modal>
{{ metric }} {{ title }}
</div> </div>
</template> </template>
...@@ -34,23 +34,25 @@ export default { ...@@ -34,23 +34,25 @@ export default {
}, },
}, },
detailedMetrics: [ detailedMetrics: [
{ metric: 'pg', header: s__('PerformanceBar|SQL queries'), details: 'queries', keys: ['sql'] }, {
metric: 'active-record',
title: 'pg',
header: s__('PerformanceBar|SQL queries'),
keys: ['sql'],
},
{ {
metric: 'gitaly', metric: 'gitaly',
header: s__('PerformanceBar|Gitaly calls'), header: s__('PerformanceBar|Gitaly calls'),
details: 'details',
keys: ['feature', 'request'], keys: ['feature', 'request'],
}, },
{ {
metric: 'rugged', metric: 'rugged',
header: s__('PerformanceBar|Rugged calls'), header: s__('PerformanceBar|Rugged calls'),
details: 'details',
keys: ['feature', 'args'], keys: ['feature', 'args'],
}, },
{ {
metric: 'redis', metric: 'redis',
header: s__('PerformanceBar|Redis calls'), header: s__('PerformanceBar|Redis calls'),
details: 'details',
keys: ['cmd'], keys: ['cmd'],
}, },
], ],
...@@ -118,8 +120,8 @@ export default { ...@@ -118,8 +120,8 @@ export default {
:key="metric.metric" :key="metric.metric"
:current-request="currentRequest" :current-request="currentRequest"
:metric="metric.metric" :metric="metric.metric"
:title="metric.title"
:header="metric.header" :header="metric.header"
:details="metric.details"
:keys="metric.keys" :keys="metric.keys"
/> />
<div v-if="initialRequest" id="peek-view-rblineprof" class="view"> <div v-if="initialRequest" id="peek-view-rblineprof" class="view">
......
Rails.application.config.peek.adapter = :redis, { client: ::Redis.new(Gitlab::Redis::Cache.params) } require 'peek/adapters/redis'
Peek.into Peek::Views::Host
if Gitlab::Database.postgresql? Peek::Adapters::Redis.prepend ::Gitlab::PerformanceBar::RedisAdapterWhenPeekEnabled
require 'peek-pg'
PEEK_DB_CLIENT = ::PG::Connection
PEEK_DB_VIEW = Peek::Views::PG
# Remove once we have https://github.com/peek/peek-pg/pull/10 Rails.application.config.peek.adapter = :redis, { client: ::Redis.new(Gitlab::Redis::Cache.params) }
module ::Peek::PGInstrumented
def exec_params(*args)
start = Time.now
super(*args)
ensure
duration = (Time.now - start)
PEEK_DB_CLIENT.query_time.update { |value| value + duration }
PEEK_DB_CLIENT.query_count.update { |value| value + 1 }
end
end
else
raise "Unsupported database adapter for peek!"
end
Peek.into PEEK_DB_VIEW Peek.into Peek::Views::Host
Peek.into Peek::Views::ActiveRecord
Peek.into Peek::Views::Gitaly Peek.into Peek::Views::Gitaly
Peek.into Peek::Views::Rblineprof Peek.into Peek::Views::Rblineprof
Peek.into Peek::Views::RedisDetailed Peek.into Peek::Views::RedisDetailed
Peek.into Peek::Views::Rugged Peek.into Peek::Views::Rugged
Peek.into Peek::Views::GC Peek.into Peek::Views::GC
Peek.into Peek::Views::Tracing if Labkit::Tracing.tracing_url_enabled? Peek.into Peek::Views::Tracing if Labkit::Tracing.tracing_url_enabled?
# rubocop:disable Naming/ClassAndModuleCamelCase
class PEEK_DB_CLIENT
class << self
attr_accessor :query_details
end
self.query_details = Concurrent::Array.new
end
PEEK_DB_VIEW.prepend ::Gitlab::PerformanceBar::PeekQueryTracker
require 'peek/adapters/redis'
Peek::Adapters::Redis.prepend ::Gitlab::PerformanceBar::RedisAdapterWhenPeekEnabled
# frozen_string_literal: true
# Inspired by https://github.com/peek/peek-pg/blob/master/lib/peek/views/pg.rb
# PEEK_DB_CLIENT is a constant set in config/initializers/peek.rb
module Gitlab
module PerformanceBar
module PeekQueryTracker
def sorted_queries
PEEK_DB_CLIENT.query_details
.sort { |a, b| b[:duration] <=> a[:duration] }
end
def results
super.merge(queries: sorted_queries)
end
private
def setup_subscribers
super
# Reset each counter when a new request starts
before_request do
PEEK_DB_CLIENT.query_details = []
end
subscribe('sql.active_record') do |_, start, finish, _, data|
if Gitlab::SafeRequestStore.store[:peek_enabled]
unless data[:cached]
backtrace = Gitlab::Profiler.clean_backtrace(caller)
track_query(data[:sql].strip, data[:binds], backtrace, start, finish)
end
end
end
end
def track_query(raw_query, bindings, backtrace, start, finish)
duration = (finish - start) * 1000.0
query_info = { duration: duration.round(3), sql: raw_query, backtrace: backtrace }
PEEK_DB_CLIENT.query_details << query_info
end
end
end
end
# frozen_string_literal: true
module Peek
module Views
class ActiveRecord < DetailedView
private
def setup_subscribers
super
subscribe('sql.active_record') do |_, start, finish, _, data|
if Gitlab::SafeRequestStore.store[:peek_enabled]
unless data[:cached]
detail_store << {
duration: finish - start,
sql: data[:sql].strip,
backtrace: Gitlab::Profiler.clean_backtrace(caller)
}
end
end
end
end
end
end
end
...@@ -11,22 +11,26 @@ module Peek ...@@ -11,22 +11,26 @@ module Peek
} }
end end
def detail_store
::Gitlab::SafeRequestStore["#{key}_call_details"] ||= []
end
private private
def duration def duration
raise NotImplementedError detail_store.map { |entry| entry[:duration] }.sum # rubocop:disable CodeReuse/ActiveRecord
end end
def calls def calls
raise NotImplementedError detail_store.count
end end
def call_details def call_details
raise NotImplementedError detail_store
end end
def format_call_details(call) def format_call_details(call)
raise NotImplementedError call.merge(duration: (call[:duration] * 1000).round(3))
end end
def details def details
......
...@@ -20,8 +20,7 @@ module Peek ...@@ -20,8 +20,7 @@ module Peek
def format_call_details(call) def format_call_details(call)
pretty_request = call[:request]&.reject { |k, v| v.blank? }.to_h.pretty_inspect pretty_request = call[:request]&.reject { |k, v| v.blank? }.to_h.pretty_inspect
call.merge(duration: (call[:duration] * 1000).round(3), super.merge(request: pretty_request || {})
request: pretty_request || {})
end end
def setup_subscribers def setup_subscribers
......
...@@ -42,27 +42,10 @@ module Peek ...@@ -42,27 +42,10 @@ module Peek
'redis' 'redis'
end end
def detail_store
::Gitlab::SafeRequestStore['redis_call_details'] ||= []
end
private private
def duration
detail_store.map { |entry| entry[:duration] }.sum # rubocop:disable CodeReuse/ActiveRecord
end
def calls
detail_store.count
end
def call_details
detail_store
end
def format_call_details(call) def format_call_details(call)
call.merge(cmd: format_command(call[:cmd]), super.merge(cmd: format_command(call[:cmd]))
duration: (call[:duration] * 1000).round(3))
end end
def format_command(cmd) def format_command(cmd)
......
...@@ -24,8 +24,7 @@ module Peek ...@@ -24,8 +24,7 @@ module Peek
end end
def format_call_details(call) def format_call_details(call)
call.merge(duration: (call[:duration] * 1000).round(3), super.merge(args: format_args(call[:args]))
args: format_args(call[:args]))
end end
def format_args(args) def format_args(args)
......
...@@ -44,7 +44,6 @@ describe('detailedMetric', () => { ...@@ -44,7 +44,6 @@ describe('detailedMetric', () => {
}, },
metric: 'gitaly', metric: 'gitaly',
header: 'Gitaly calls', header: 'Gitaly calls',
details: 'details',
keys: ['feature', 'request'], keys: ['feature', 'request'],
}); });
}); });
...@@ -79,8 +78,32 @@ describe('detailedMetric', () => { ...@@ -79,8 +78,32 @@ describe('detailedMetric', () => {
}); });
}); });
it('displays the metric name', () => { it('displays the metric title', () => {
expect(vm.$el.innerText).toContain('gitaly'); expect(vm.$el.innerText).toContain('gitaly');
}); });
describe('when using a custom metric title', () => {
beforeEach(() => {
vm = mountComponent(Vue.extend(detailedMetric), {
currentRequest: {
details: {
gitaly: {
duration: '123ms',
calls: '456',
details: requestDetails,
},
},
},
metric: 'gitaly',
title: 'custom',
header: 'Gitaly calls',
keys: ['feature', 'request'],
});
});
it('displays the custom title', () => {
expect(vm.$el.innerText).toContain('custom');
});
});
}); });
}); });
...@@ -816,7 +816,6 @@ pbkdf2,3.0.14,MIT ...@@ -816,7 +816,6 @@ pbkdf2,3.0.14,MIT
peek,1.0.1,MIT peek,1.0.1,MIT
peek-gc,0.0.2,MIT peek-gc,0.0.2,MIT
peek-mysql2,1.1.0,MIT peek-mysql2,1.1.0,MIT
peek-pg,1.3.0,MIT
peek-rblineprof,0.2.0,MIT peek-rblineprof,0.2.0,MIT
peek-redis,1.2.0,MIT peek-redis,1.2.0,MIT
pg,0.18.4,"BSD,ruby,GPL" pg,0.18.4,"BSD,ruby,GPL"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment