Class: Datadog::Tracing::Sampling::RateByKeySampler

Inherits:
Sampler
  • Object
show all
Defined in:
lib/datadog/tracing/sampling/rate_by_key_sampler.rb

Overview

Samples at different rates by key.

Direct Known Subclasses

RateByServiceSampler

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(default_key, default_rate = 1.0, decision: nil, &block) ⇒ RateByKeySampler

Returns a new instance of RateByKeySampler.

Raises:

  • (ArgumentError)


15
16
17
18
19
20
21
22
23
24
25
26
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 15

def initialize(default_key, default_rate = 1.0, decision: nil, &block)
  super()

  raise ArgumentError, 'No resolver given!' unless block

  @default_key = default_key
  @resolver = block
  @mutex = Mutex.new
  @samplers = {}

  set_rate(default_key, default_rate, decision)
end

Instance Attribute Details

#default_keyObject (readonly)

Returns the value of attribute default_key.



12
13
14
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 12

def default_key
  @default_key
end

Instance Method Details

#default_samplerObject



32
33
34
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 32

def default_sampler
  @samplers[default_key]
end

#delete(key) ⇒ Object



72
73
74
75
76
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 72

def delete(key)
  @mutex.synchronize do
    @samplers.delete(key)
  end
end

#delete_if(&block) ⇒ Object



78
79
80
81
82
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 78

def delete_if(&block)
  @mutex.synchronize do
    @samplers.delete_if(&block)
  end
end

#lengthObject



84
85
86
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 84

def length
  @samplers.length
end

#resolve(trace) ⇒ Object



28
29
30
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 28

def resolve(trace)
  @resolver.call(trace)
end

#sample!(trace) ⇒ Object



44
45
46
47
48
49
50
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 44

def sample!(trace)
  key = resolve(trace)

  @mutex.synchronize do
    @samplers.fetch(key, default_sampler).sample!(trace)
  end
end

#sample?(trace) ⇒ Boolean

Returns:

  • (Boolean)


36
37
38
39
40
41
42
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 36

def sample?(trace)
  key = resolve(trace)

  @mutex.synchronize do
    @samplers.fetch(key, default_sampler).sample?(trace)
  end
end

#sample_rate(trace) ⇒ Object



52
53
54
55
56
57
58
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 52

def sample_rate(trace)
  key = resolve(trace)

  @mutex.synchronize do
    @samplers.fetch(key, default_sampler).sample_rate
  end
end

#update(key, rate, decision: nil) ⇒ Object



60
61
62
63
64
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 60

def update(key, rate, decision: nil)
  @mutex.synchronize do
    set_rate(key, rate, decision)
  end
end

#update_all(rate_by_key, decision: nil) ⇒ Object



66
67
68
69
70
# File 'lib/datadog/tracing/sampling/rate_by_key_sampler.rb', line 66

def update_all(rate_by_key, decision: nil)
  @mutex.synchronize do
    rate_by_key.each { |key, rate| set_rate(key, rate, decision) }
  end
end