Sha256: f041e57a1b8d68c694b6ddbaa7dee48c9e549620a77b3a4dd4d8e79a30323856
Contents?: true
Size: 1.43 KB
Versions: 9
Compression:
Stored size: 1.43 KB
Contents
# frozen_string_literal: true require_relative '../../ext' require_relative '../../event' require_relative '../../consumer_event' module Datadog module Tracing module Contrib module Kafka module Events module Consumer # Defines instrumentation for process_message.consumer.kafka event module ProcessMessage include Kafka::Event extend Kafka::ConsumerEvent EVENT_NAME = 'process_message.consumer.kafka' module_function def on_start(span, _event, _id, payload) super span.resource = payload[:topic] span.set_tag(Ext::TAG_TOPIC, payload[:topic]) if payload.key?(:topic) span.set_tag(Ext::TAG_MESSAGE_KEY, payload[:key]) if payload.key?(:key) span.set_tag(Ext::TAG_PARTITION, payload[:partition]) if payload.key?(:partition) span.set_tag(Ext::TAG_OFFSET, payload[:offset]) if payload.key?(:offset) span.set_tag(Ext::TAG_OFFSET_LAG, payload[:offset_lag]) if payload.key?(:offset_lag) end def span_name Ext::SPAN_PROCESS_MESSAGE end def span_options super.merge({ tags: { Tracing::Metadata::Ext::TAG_OPERATION => Ext::TAG_OPERATION_PROCESS_MESSAGE } }) end end end end end end end end
Version data entries
9 entries across 9 versions & 1 rubygems