app_profiler 0.2.3 → 0.2.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/app_profiler/backend/base_backend.rb +1 -1
- data/lib/app_profiler/middleware.rb +0 -1
- data/lib/app_profiler/profile/stackprof.rb +4 -0
- data/lib/app_profiler/profile/vernier.rb +4 -0
- data/lib/app_profiler/profile.rb +1 -1
- data/lib/app_profiler/sampler/config.rb +11 -6
- data/lib/app_profiler/sampler.rb +14 -4
- data/lib/app_profiler/version.rb +1 -1
- data/lib/app_profiler.rb +24 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 36a0afed63f70a16ab782039e981583c16e80f846eb6caf6cefce219d7934d0d
|
4
|
+
data.tar.gz: eda36bd2a579b25757db0e872c3f2aa1cbdda60ddf486b4bd3ad90f34f74829c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8ef999eb872722bca7b910b88df8a091c756b4d9f0e95da4ac770aacfb0b5454a160ca37b8c13852e25e5fd8aecf698f6bc06f6669104cbbb02c5af033b66a80
|
7
|
+
data.tar.gz: 2896ca3138e8b631445b628bcd6206e77bcd94fbef57c00560b0a63f8677b3103555eef97aabbb936722406d5667ec6c8885c9224fe85cd82d2619f45fdb9051
|
@@ -40,7 +40,7 @@ module AppProfiler
|
|
40
40
|
end
|
41
41
|
|
42
42
|
def release_run_lock
|
43
|
-
self.class.run_lock.unlock
|
43
|
+
self.class.run_lock.unlock if self.class.run_lock.locked?
|
44
44
|
rescue ThreadError
|
45
45
|
AppProfiler.logger.warn("[AppProfiler] run lock not released as it was never acquired")
|
46
46
|
end
|
data/lib/app_profiler/profile.rb
CHANGED
@@ -5,19 +5,21 @@ require "app_profiler/sampler/vernier_config"
|
|
5
5
|
module AppProfiler
|
6
6
|
module Sampler
|
7
7
|
class Config
|
8
|
-
attr_reader :sample_rate, :
|
8
|
+
attr_reader :sample_rate, :targets, :exclude_targets, :cpu_interval, :backends_probability
|
9
9
|
|
10
10
|
SAMPLE_RATE = 0.001 # 0.1%
|
11
|
-
|
11
|
+
TARGETS = ["/"]
|
12
12
|
BACKEND_PROBABILITES = { stackprof: 1.0, vernier: 0.0 }
|
13
|
-
|
13
|
+
EMPTY_ARRAY = []
|
14
14
|
|
15
15
|
def initialize(sample_rate: SAMPLE_RATE,
|
16
|
-
|
16
|
+
targets: TARGETS,
|
17
17
|
backends_probability: BACKEND_PROBABILITES,
|
18
18
|
backends_config: {
|
19
19
|
stackprof: StackprofConfig.new,
|
20
|
-
}
|
20
|
+
},
|
21
|
+
paths: nil,
|
22
|
+
exclude_targets: EMPTY_ARRAY)
|
21
23
|
|
22
24
|
if sample_rate < 0.0 || sample_rate > 1.0
|
23
25
|
raise ArgumentError, "sample_rate must be between 0 and 1"
|
@@ -25,10 +27,13 @@ module AppProfiler
|
|
25
27
|
|
26
28
|
raise ArgumentError, "mode probabilities must sum to 1" unless backends_probability.values.sum == 1.0
|
27
29
|
|
30
|
+
ActiveSupport::Deprecation.new.warn("passing paths is deprecated, use targets instead") if paths
|
31
|
+
|
28
32
|
@sample_rate = sample_rate
|
29
|
-
@
|
33
|
+
@targets = paths || targets
|
30
34
|
@backends_config = backends_config
|
31
35
|
@backends_probability = backends_probability
|
36
|
+
@exclude_targets = exclude_targets
|
32
37
|
end
|
33
38
|
|
34
39
|
def get_backend_config(backend_name)
|
data/lib/app_profiler/sampler.rb
CHANGED
@@ -3,20 +3,30 @@
|
|
3
3
|
require "app_profiler/sampler/config"
|
4
4
|
module AppProfiler
|
5
5
|
module Sampler
|
6
|
+
@excluded_cache = {}
|
6
7
|
class << self
|
7
8
|
def profile_params(request, config)
|
8
|
-
|
9
|
+
profile_params_for(request.path, config)
|
10
|
+
end
|
11
|
+
|
12
|
+
def profile_params_for(target, config)
|
13
|
+
return unless sample?(config, target)
|
9
14
|
|
10
15
|
get_profile_params(config)
|
11
16
|
end
|
12
17
|
|
13
18
|
private
|
14
19
|
|
15
|
-
def sample?(config,
|
20
|
+
def sample?(config, target)
|
16
21
|
return false if Kernel.rand > config.sample_rate
|
22
|
+
return false if @excluded_cache[target]
|
23
|
+
|
24
|
+
if config.exclude_targets.any? { |t| target.match?(t) }
|
25
|
+
@excluded_cache[target] = true
|
26
|
+
return false
|
27
|
+
end
|
17
28
|
|
18
|
-
|
19
|
-
return false unless config.paths.any? { |p| path.match?(p) }
|
29
|
+
return false unless config.targets.any? { |t| target.match?(t) }
|
20
30
|
|
21
31
|
true
|
22
32
|
end
|
data/lib/app_profiler/version.rb
CHANGED
data/lib/app_profiler.rb
CHANGED
@@ -1,5 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
require "active_support"
|
3
4
|
require "active_support/core_ext/class"
|
4
5
|
require "active_support/core_ext/module"
|
5
6
|
require "logger"
|
@@ -63,7 +64,7 @@ module AppProfiler
|
|
63
64
|
mattr_reader :profile_enqueue_failure, default: nil
|
64
65
|
mattr_reader :after_process_queue, default: nil
|
65
66
|
mattr_accessor :forward_metadata_on_upload, default: false
|
66
|
-
|
67
|
+
|
67
68
|
mattr_accessor :profile_sampler_config
|
68
69
|
|
69
70
|
class << self
|
@@ -116,6 +117,28 @@ module AppProfiler
|
|
116
117
|
@profiler_backend = new_profiler_backend
|
117
118
|
end
|
118
119
|
|
120
|
+
def profile_sampler_enabled=(value)
|
121
|
+
if value.is_a?(Proc)
|
122
|
+
raise ArgumentError,
|
123
|
+
"profile_sampler_enabled must be a proc or a lambda that accepts no argument" if value.arity != 0
|
124
|
+
else
|
125
|
+
raise ArgumentError, "Must be TrueClass or FalseClass" unless [TrueClass, FalseClass].include?(value.class)
|
126
|
+
end
|
127
|
+
|
128
|
+
@profile_sampler_enabled = value
|
129
|
+
end
|
130
|
+
|
131
|
+
def profile_sampler_enabled
|
132
|
+
return false unless defined?(@profile_sampler_enabled)
|
133
|
+
|
134
|
+
@profile_sampler_enabled.is_a?(Proc) ? @profile_sampler_enabled.call : @profile_sampler_enabled
|
135
|
+
rescue => e
|
136
|
+
logger.error(
|
137
|
+
"[AppProfiler.profile_sampler_enabled] exception: #{e}, message: #{e.message}",
|
138
|
+
)
|
139
|
+
false
|
140
|
+
end
|
141
|
+
|
119
142
|
def backend_for(backend_name)
|
120
143
|
if vernier_supported? &&
|
121
144
|
backend_name == AppProfiler::Backend::VernierBackend.name
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: app_profiler
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Gannon McGibbon
|
@@ -13,7 +13,7 @@ authors:
|
|
13
13
|
autorequire:
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
|
-
date: 2024-
|
16
|
+
date: 2024-10-15 00:00:00.000000000 Z
|
17
17
|
dependencies:
|
18
18
|
- !ruby/object:Gem::Dependency
|
19
19
|
name: activesupport
|
@@ -184,7 +184,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
184
184
|
- !ruby/object:Gem::Version
|
185
185
|
version: '0'
|
186
186
|
requirements: []
|
187
|
-
rubygems_version: 3.5.
|
187
|
+
rubygems_version: 3.5.21
|
188
188
|
signing_key:
|
189
189
|
specification_version: 4
|
190
190
|
summary: Collect performance profiles for your Rails application.
|