Class: Sentry::Vernier::Profiler
- Inherits:
-
Object
- Object
- Sentry::Vernier::Profiler
- Defined in:
- lib/sentry/vernier/profiler.rb
Constant Summary collapse
- EMPTY_RESULT =
{}.freeze
Instance Attribute Summary collapse
-
#event_id ⇒ Object
readonly
Returns the value of attribute event_id.
-
#result ⇒ Object
readonly
Returns the value of attribute result.
-
#started ⇒ Object
readonly
Returns the value of attribute started.
Instance Method Summary collapse
- #active_thread_id ⇒ Object
-
#initialize(configuration) ⇒ Profiler
constructor
A new instance of Profiler.
- #set_initial_sample_decision(transaction_sampled) ⇒ Object
- #start ⇒ Object
- #stop ⇒ Object
- #to_hash ⇒ Object
Constructor Details
#initialize(configuration) ⇒ Profiler
Returns a new instance of Profiler.
14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/sentry/vernier/profiler.rb', line 14 def initialize(configuration) @event_id = SecureRandom.uuid.delete("-") @started = false @sampled = nil @profiling_enabled = defined?(Vernier) && configuration.profiling_enabled? @profiles_sample_rate = configuration.profiles_sample_rate @project_root = configuration.project_root @app_dirs_pattern = configuration.app_dirs_pattern @in_app_pattern = Regexp.new("^(#{@project_root}/)?#{@app_dirs_pattern}") end |
Instance Attribute Details
#event_id ⇒ Object (readonly)
Returns the value of attribute event_id.
12 13 14 |
# File 'lib/sentry/vernier/profiler.rb', line 12 def event_id @event_id end |
#result ⇒ Object (readonly)
Returns the value of attribute result.
12 13 14 |
# File 'lib/sentry/vernier/profiler.rb', line 12 def result @result end |
#started ⇒ Object (readonly)
Returns the value of attribute started.
12 13 14 |
# File 'lib/sentry/vernier/profiler.rb', line 12 def started @started end |
Instance Method Details
#active_thread_id ⇒ Object
87 88 89 |
# File 'lib/sentry/vernier/profiler.rb', line 87 def active_thread_id Thread.current.object_id end |
#set_initial_sample_decision(transaction_sampled) ⇒ Object
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/sentry/vernier/profiler.rb', line 27 def set_initial_sample_decision(transaction_sampled) unless @profiling_enabled @sampled = false return end unless transaction_sampled @sampled = false log("Discarding profile because transaction not sampled") return end case @profiles_sample_rate when 0.0 @sampled = false log("Discarding profile because sample_rate is 0") return when 1.0 @sampled = true return else @sampled = Random.rand < @profiles_sample_rate end log("Discarding profile due to sampling decision") unless @sampled end |
#start ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
# File 'lib/sentry/vernier/profiler.rb', line 54 def start return unless @sampled return if @started @started = ::Vernier.start_profile log("Started") @started rescue RuntimeError => e # TODO: once Vernier raises something more dedicated, we should catch that instead if e..include?("Profile already started") log("Not started since running elsewhere") else log("Failed to start: #{e.}") end end |
#stop ⇒ Object
72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/sentry/vernier/profiler.rb', line 72 def stop return unless @sampled return unless @started @result = ::Vernier.stop_profile log("Stopped") rescue RuntimeError => e if e..include?("Profile not started") log("Not stopped since not started") else log("Failed to stop Vernier: #{e.}") end end |
#to_hash ⇒ Object
91 92 93 94 95 96 97 98 99 100 |
# File 'lib/sentry/vernier/profiler.rb', line 91 def to_hash return EMPTY_RESULT unless @started unless @sampled record_lost_event(:sample_rate) return EMPTY_RESULT end { **, profile: output.to_h } end |