Skip to content

Commit

Permalink
Add option to ignore garbage collection frames with flamegraphs (#599)
Browse files Browse the repository at this point in the history
* Add flamegraph_ignore_gc config

* Add flamegraph_ignore_gc to query params
  • Loading branch information
ihollander authored Dec 7, 2023
1 parent f239b6e commit 710a5ed
Show file tree
Hide file tree
Showing 5 changed files with 15 additions and 2 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -431,6 +431,7 @@ start_hidden | `false`
backtrace_threshold_ms | `0` | Minimum SQL query elapsed time before a backtrace is recorded.
flamegraph_sample_rate | `0.5` | How often to capture stack traces for flamegraphs in milliseconds.
flamegraph_mode | `:wall` | The [StackProf mode](https://github.com/tmm1/stackprof#all-options) to pass to `StackProf.run`.
flamegraph_ignore_gc | `false` | Whether to ignore garbage collection frames in flamegraphs.
base_url_path | `'/mini-profiler-resources/'` | Path for assets; added as a prefix when naming assets and sought when responding to requests.
cookie_path | `'/'` | Set-Cookie header path for profile cookie
collapse_results | `true` | If multiple timing results exist in a single page, collapse them till clicked.
Expand Down
11 changes: 10 additions & 1 deletion lib/mini_profiler.rb
Original file line number Diff line number Diff line change
Expand Up @@ -302,11 +302,20 @@ def call(env)
mode = config.flamegraph_mode
end

ignore_gc_match_data = action_parameters(env)['flamegraph_ignore_gc']

if ignore_gc_match_data
ignore_gc = ignore_gc_match_data == 'true'
else
ignore_gc = config.flamegraph_ignore_gc
end

flamegraph = StackProf.run(
mode: mode,
raw: true,
aggregate: false,
interval: (sample_rate * 1000).to_i
interval: (sample_rate * 1000).to_i,
ignore_gc: ignore_gc
) do
status, headers, body = @app.call(env)
end
Expand Down
3 changes: 2 additions & 1 deletion lib/mini_profiler/config.rb
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ def self.default
@backtrace_threshold_ms = 0
@flamegraph_sample_rate = 0.5
@flamegraph_mode = :wall
@flamegraph_ignore_gc = false
@storage_failure = Proc.new do |exception|
if @logger
@logger.warn("MiniProfiler storage failure: #{exception.message}")
Expand Down Expand Up @@ -76,7 +77,7 @@ def self.default
:storage_options, :user_provider, :enable_advanced_debugging_tools,
:skip_sql_param_names, :suppress_encoding, :max_sql_param_length,
:content_security_policy_nonce, :enable_hotwire_turbo_drive_support,
:flamegraph_mode, :profile_parameter
:flamegraph_mode, :flamegraph_ignore_gc, :profile_parameter

# ui accessors
attr_accessor :collapse_results, :max_traces_to_show, :position,
Expand Down
1 change: 1 addition & 0 deletions lib/mini_profiler/views.rb
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,7 @@ def help(client_settings, env)
#{make_link "async-flamegraph", env} : store flamegraph data for this page and all its AJAX requests. Flamegraph links will be available in the mini-profiler UI (requires the stackprof gem).
#{make_link "flamegraph&flamegraph_sample_rate=1", env}: creates a flamegraph with the specified sample rate (in ms). Overrides value set in config
#{make_link "flamegraph&flamegraph_mode=cpu", env}: creates a flamegraph with the specified mode (one of cpu, wall, object, or custom). Overrides value set in config
#{make_link "flamegraph&flamegraph_ignore_gc=true", env}: ignore garbage collection frames in flamegraphs. Overrides value set in config
#{make_link "flamegraph_embed", env} : a graph representing sampled activity (requires the stackprof gem), embedded resources for use on an intranet.
#{make_link "trace-exceptions", env} : will return all the spots where your application raises exceptions
#{make_link "analyze-memory", env} : will perform basic memory analysis of heap
Expand Down
1 change: 1 addition & 0 deletions spec/integration/middleware_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ def app
expect(last_response.body).to include("async-flamegraph")
expect(last_response.body).to include("flamegraph&flamegraph_sample_rate=1")
expect(last_response.body).to include("flamegraph&flamegraph_mode=cpu")
expect(last_response.body).to include("flamegraph&flamegraph_ignore_gc=true")
expect(last_response.body).to include("flamegraph_embed")
expect(last_response.body).to include("trace-exceptions")
expect(last_response.body).to include("analyze-memory")
Expand Down

0 comments on commit 710a5ed

Please sign in to comment.