Class: Mixpanel::BufferedConsumer

Inherits:
Object
  • Object
show all
Defined in:
lib/mixpanel-ruby/consumer.rb

Overview

BufferedConsumer buffers messages in memory, and sends messages as a batch. This can improve performance, but calls to #send may still block if the buffer is full. If you use this consumer, you should call #flush when your application exits or the messages remaining in the buffer will not be sent.

To use a BufferedConsumer directly with a Mixpanel::Tracker, instantiate your Tracker like this

buffered_consumer = Mixpanel::BufferedConsumer.new
begin
    buffered_tracker = Mixpanel::Tracker.new(YOUR_TOKEN) do |type, message|
        buffered_consumer.send(type, message)
    end
    # Do some tracking here
    ...
ensure
    buffered_consumer.flush
end

Constant Summary collapse

MAX_LENGTH =
50

Instance Method Summary collapse

Constructor Details

#initialize(events_endpoint = nil, update_endpoint = nil, import_endpoint = nil, max_buffer_length = MAX_LENGTH, &block) ⇒ BufferedConsumer

Create a Mixpanel::BufferedConsumer. If you provide endpoint arguments, they will be used instead of the default Mixpanel endpoints. This can be useful for proxying, debugging, or if you prefer not to use SSL for your events.

You can also change the preferred buffer size before the consumer automatically sends its buffered events. The Mixpanel endpoints have a limit of 50 events per HTTP request, but you can lower the limit if your individual events are very large.

By default, BufferedConsumer will use a standard Mixpanel consumer to send the events once the buffer is full (or on calls to #flush), but you can override this behavior by passing a block to the constructor, in the same way you might pass a block to the Mixpanel::Tracker constructor. If a block is passed to the constructor, the *_endpoint constructor arguments are ignored.



184
185
186
187
188
189
190
191
192
193
194
195
196
# File 'lib/mixpanel-ruby/consumer.rb', line 184

def initialize(events_endpoint=nil, update_endpoint=nil, import_endpoint=nil, max_buffer_length=MAX_LENGTH, &block)
  @max_length = [max_buffer_length, MAX_LENGTH].min
  if block
    @sink = block
  else
    consumer = Consumer.new(events_endpoint, update_endpoint, import_endpoint)
    @sink = consumer.method(:send)
  end
  @buffers = {
    :event => [],
    :profile_update => [],
  }
end

Instance Method Details

#flushObject

Pushes all remaining messages in the buffer to Mixpanel. You should call #flush before your application exits or messages may not be sent.



219
220
221
# File 'lib/mixpanel-ruby/consumer.rb', line 219

def flush
  @buffers.keys.each { |k| flush_type(k) }
end

#send(type, message) ⇒ Object

Stores a message for Mixpanel in memory. When the buffer hits a maximum length, the consumer will flush automatically. Flushes are synchronous when they occur.

Currently, only :event and :profile_update messages are buffered, :import messages will be send immediately on call.



204
205
206
207
208
209
210
211
212
213
214
# File 'lib/mixpanel-ruby/consumer.rb', line 204

def send(type, message)
  type = type.to_sym
  if @buffers.has_key? type
    @buffers[type] << message
    if @buffers[type].length >= @max_length
      flush_type(type)
    end
  else
    @sink.call(type, message)
  end
end