Sha256: 87ed352e754332421ad1ab50ae1ed9fd0575735422b68aea98b4b4e0548bb495

Contents?: true

Size: 734 Bytes

Versions: 11

Compression:

Stored size: 734 Bytes

Contents

# frozen_string_literal: true

module Deimos
  module Backends
    # Backend which produces to Kafka via an async producer.
    class KafkaAsync < Deimos::PublishBackend
      include Phobos::Producer

      # :nodoc:
      def self.execute(producer_class:, messages:)
        Deimos.instrument(
          'produce',
          producer: producer_class,
          topic: producer_class.topic,
          payloads: messages.map(&:payload)
        ) do
          producer.async_publish_list(messages.map(&:encoded_hash))
          Deimos.config.metrics&.increment(
            'publish',
            tags: %W(status:success topic:#{producer_class.topic}),
            by: messages.size
          )
        end
      end
    end
  end
end

Version data entries

11 entries across 11 versions & 2 rubygems

Version Path
deimos-ruby-1.0.0.pre.beta25 lib/deimos/backends/kafka_async.rb
deimos-ruby-1.0.0.pre.beta24 lib/deimos/backends/kafka_async.rb
deimos-ruby-1.0.0.pre.beta23 lib/deimos/backends/kafka_async.rb
deimos-ruby-1.0.0.pre.beta22 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta21 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta20 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta19 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta18 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta17 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta16 lib/deimos/backends/kafka_async.rb
deimos-kafka-1.0.0.pre.beta15 lib/deimos/backends/kafka_async.rb