Class: Datadog::Statsd::SingleThreadSender
- Inherits:
-
Object
- Object
- Datadog::Statsd::SingleThreadSender
- Defined in:
- lib/datadog/statsd/single_thread_sender.rb
Overview
The SingleThreadSender is a sender synchronously buffering messages in a `MessageBuffer`. It is using current Process.PID to check it is the result of a recent fork and it is reseting the MessageBuffer if that's the case.
Instance Method Summary collapse
- #add(message) ⇒ Object
- #flush ⇒ Object
-
#initialize(message_buffer, logger: nil, flush_interval: nil) ⇒ SingleThreadSender
constructor
A new instance of SingleThreadSender.
-
#rendez_vous ⇒ Object
Compatibility with `Sender`.
- #start ⇒ Object
- #stop ⇒ Object
Constructor Details
#initialize(message_buffer, logger: nil, flush_interval: nil) ⇒ SingleThreadSender
Returns a new instance of SingleThreadSender.
10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 10 def initialize(, logger: nil, flush_interval: nil) @message_buffer = @logger = logger @mx = Mutex.new @flush_timer = if flush_interval Datadog::Statsd::Timer.new(flush_interval) { flush } else nil end # store the pid for which this sender has been created update_fork_pid end |
Instance Method Details
#add(message) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 23 def add() @mx.synchronize { # we have just forked, meaning we have messages in the buffer that we should # not send, they belong to the parent process, let's clear the buffer. if forked? @message_buffer.reset @flush_timer.start if @flush_timer && @flush_timer.stop? update_fork_pid end @message_buffer.add() } end |
#flush ⇒ Object
36 37 38 39 40 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 36 def flush(*) @mx.synchronize { @message_buffer.flush() } end |
#rendez_vous ⇒ Object
Compatibility with `Sender`
51 52 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 51 def rendez_vous() end |
#start ⇒ Object
42 43 44 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 42 def start() @flush_timer.start if @flush_timer end |
#stop ⇒ Object
46 47 48 |
# File 'lib/datadog/statsd/single_thread_sender.rb', line 46 def stop() @flush_timer.stop if @flush_timer end |