app_profiler 0.2.3 → 0.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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.
|