Sha256: 7dde6cdd75ee7e53bfae2ada69a075ebfb11ed9e359c1038b09e67b7a0c48bb2
Contents?: true
Size: 1.51 KB
Versions: 2
Compression:
Stored size: 1.51 KB
Contents
class Freddy module Producers class SendAndForgetProducer CONTENT_TYPE = 'application/json'.freeze def initialize(channel, logger) @logger = logger @exchange = channel.default_exchange @topic_exchange = channel.topic Freddy::FREDDY_TOPIC_EXCHANGE_NAME end def produce(destination, payload, properties) span = OpenTracing.start_span("freddy:notify:#{destination}", tags: { 'message_bus.destination': destination, 'component': 'freddy', 'span.kind': 'producer' # Message Bus } ) span.log_kv event: 'Sending message', payload: payload properties = properties.merge( routing_key: destination, content_type: CONTENT_TYPE ) OpenTracing.global_tracer.inject(span.context, OpenTracing::FORMAT_TEXT_MAP, TraceCarrier.new(properties)) json_payload = Payload.dump(payload) # Connection adapters handle thread safety for #publish themselves. No # need to lock these. @topic_exchange.publish json_payload, properties.dup @exchange.publish json_payload, properties.dup ensure # We don't know how many listeners there are and we do not know when # this message gets processed. Instead we close the span immediately. # Listeners should use FollowsFrom to add trace information. # https://github.com/opentracing/specification/blob/master/specification.md span.finish end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
freddy-1.4.1 | lib/freddy/producers/send_and_forget_producer.rb |
freddy-1.4.0 | lib/freddy/producers/send_and_forget_producer.rb |