diff options
author | Rémy Coutable <remy@rymai.me> | 2018-07-19 15:36:38 +0000 |
---|---|---|
committer | Rémy Coutable <remy@rymai.me> | 2018-07-19 15:36:38 +0000 |
commit | be2410ab18136df8ffc81d667879b4fefa61b732 (patch) | |
tree | 7332a634f09eaf0c30bc449996ccd274037539ba /lib | |
parent | 91fcb311f9b760d6d7222d1f761274509fafa8cd (diff) | |
parent | ef973f6f28f5b98ba126985b01d1c463e1cd8761 (diff) | |
download | gitlab-ce-be2410ab18136df8ffc81d667879b4fefa61b732.tar.gz |
Merge branch 'add-total-time-flat-printer-for-profiling' into 'master'
Add a Gitlab::Profiler.print_by_total_time convenience method
See merge request gitlab-org/gitlab-ce!20715
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gitlab/profiler.rb | 6 | ||||
-rw-r--r-- | lib/gitlab/profiler/total_time_flat_printer.rb | 39 |
2 files changed, 45 insertions, 0 deletions
diff --git a/lib/gitlab/profiler.rb b/lib/gitlab/profiler.rb index ecff6ab5d5e..c5bb4648572 100644 --- a/lib/gitlab/profiler.rb +++ b/lib/gitlab/profiler.rb @@ -146,5 +146,11 @@ module Gitlab logger.info("#{model} total (#{query_count}): #{time.round(2)}ms") end end + + def self.print_by_total_time(result, options = {}) + default_options = { sort_method: :total_time } + + Gitlab::Profiler::TotalTimeFlatPrinter.new(result).print(STDOUT, default_options.merge(options)) + end end end diff --git a/lib/gitlab/profiler/total_time_flat_printer.rb b/lib/gitlab/profiler/total_time_flat_printer.rb new file mode 100644 index 00000000000..2fd0ec10ba8 --- /dev/null +++ b/lib/gitlab/profiler/total_time_flat_printer.rb @@ -0,0 +1,39 @@ +module Gitlab + module Profiler + class TotalTimeFlatPrinter < RubyProf::FlatPrinter + def max_percent + @options[:max_percent] || 100 + end + + # Copied from: + # <https://github.com/ruby-prof/ruby-prof/blob/master/lib/ruby-prof/printers/flat_printer.rb> + # + # The changes are just to filter by total time, not self time, and add a + # max_percent option as well. + def print_methods(thread) + total_time = thread.total_time + methods = thread.methods.sort_by(&sort_method).reverse + + sum = 0 + methods.each do |method| + total_percent = (method.total_time / total_time) * 100 + next if total_percent < min_percent + next if total_percent > max_percent + + sum += method.self_time + + @output << "%6.2f %9.3f %9.3f %9.3f %9.3f %8d %s%s\n" % [ + method.self_time / total_time * 100, # %self + method.total_time, # total + method.self_time, # self + method.wait_time, # wait + method.children_time, # children + method.called, # calls + method.recursive? ? "*" : " ", # cycle + method_name(method) # name + ] + end + end + end + end +end |