Class: ScoutApm::SlowTransaction
- Inherits:
-
Object
- Object
- ScoutApm::SlowTransaction
- Defined in:
- lib/scout_apm/slow_transaction.rb
Constant Summary collapse
- BACKTRACE_THRESHOLD =
the minimum threshold to record the backtrace for a metric.
0.5
- BACKTRACE_LIMIT =
Max length of callers to display
5
- MAX_SIZE =
Limits the size of the metric hash to prevent a metric explosion.
100
Instance Attribute Summary collapse
-
#context ⇒ Object
readonly
Returns the value of attribute context.
-
#meta ⇒ Object
readonly
Returns the value of attribute meta.
-
#metric_name ⇒ Object
readonly
Returns the value of attribute metric_name.
-
#metrics ⇒ Object
readonly
Returns the value of attribute metrics.
-
#time ⇒ Object
readonly
Returns the value of attribute time.
-
#total_call_time ⇒ Object
readonly
Returns the value of attribute total_call_time.
-
#uri ⇒ Object
readonly
Returns the value of attribute uri.
Class Method Summary collapse
-
.backtrace_parser(backtrace) ⇒ Object
Given a call stack, generates a filtered backtrace that: * Limits to the app/models, app/controllers, or app/views directories * Limits to 5 total callers * Makes the app folder the top-level folder used in trace info.
Instance Method Summary collapse
-
#clear_metrics! ⇒ Object
Used to remove metrics when the payload will be too large.
-
#initialize(uri, metric_name, total_call_time, metrics, context, time) ⇒ SlowTransaction
constructor
A new instance of SlowTransaction.
Constructor Details
#initialize(uri, metric_name, total_call_time, metrics, context, time) ⇒ SlowTransaction
Returns a new instance of SlowTransaction.
22 23 24 25 26 27 28 29 |
# File 'lib/scout_apm/slow_transaction.rb', line 22 def initialize(uri,metric_name,total_call_time,metrics,context,time) @uri = uri @metric_name = metric_name @total_call_time = total_call_time @metrics = metrics @context = context @time = time end |
Instance Attribute Details
#context ⇒ Object (readonly)
Returns the value of attribute context.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def context @context end |
#meta ⇒ Object (readonly)
Returns the value of attribute meta.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def @meta end |
#metric_name ⇒ Object (readonly)
Returns the value of attribute metric_name.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def metric_name @metric_name end |
#metrics ⇒ Object (readonly)
Returns the value of attribute metrics.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def metrics @metrics end |
#time ⇒ Object (readonly)
Returns the value of attribute time.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def time @time end |
#total_call_time ⇒ Object (readonly)
Returns the value of attribute total_call_time.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def total_call_time @total_call_time end |
#uri ⇒ Object (readonly)
Returns the value of attribute uri.
5 6 7 |
# File 'lib/scout_apm/slow_transaction.rb', line 5 def uri @uri end |
Class Method Details
.backtrace_parser(backtrace) ⇒ Object
Given a call stack, generates a filtered backtrace that:
-
Limits to the app/models, app/controllers, or app/views directories
-
Limits to 5 total callers
-
Makes the app folder the top-level folder used in trace info
11 12 13 14 15 16 17 18 19 20 |
# File 'lib/scout_apm/slow_transaction.rb', line 11 def self.backtrace_parser(backtrace) stack = [] backtrace.each do |c| if m=c.match(/(\/app\/(controllers|models|views)\/.+)/) stack << m[1] break if stack.size == BACKTRACE_LIMIT end end stack end |
Instance Method Details
#clear_metrics! ⇒ Object
Used to remove metrics when the payload will be too large.
32 33 34 35 |
# File 'lib/scout_apm/slow_transaction.rb', line 32 def clear_metrics! @metrics = nil self end |