Skip to content

Latest commit

 

History

History
 
 

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Library instrumentation for Kafka Clients version 2.6 and higher

Quickstart

Add these dependencies to your project

Replace OPENTELEMETRY_VERSION with the latest release.

For Maven, add to your pom.xml dependencies:

<dependencies>
  <dependency>
    <groupId>io.opentelemetry.instrumentation</groupId>
    <artifactId>opentelemetry-kafka-clients-2.6</artifactId>
    <version>OPENTELEMETRY_VERSION</version>
  </dependency>
</dependencies>

For Gradle, add to your dependencies:

implementation("io.opentelemetry.instrumentation:opentelemetry-kafka-clients-2.6:OPENTELEMETRY_VERSION")

Usage (Tracing)

There are two options for capturing traces, either using interceptors or wrapping clients, both described below.

Using interceptors

The Kafka clients API provides a way to "intercept" messages before they are sent to the brokers as well as messages received from the broker before being passed to the application. The OpenTelemetry instrumented Kafka library provides two interceptors to be configured to add tracing information automatically. The interceptor class has to be set in the properties bag used to create the Kafka client.

Use the TracingProducerInterceptor for the producer in order to create a "send" span automatically, each time a message is sent.

props.setProperty(ProducerConfig.INTERCEPTOR_CLASSES_CONFIG, TracingProducerInterceptor.class.getName());

Use the TracingConsumerInterceptor for the consumer in order to create a "receive" span automatically, each time a message is received.

props.setProperty(ConsumerConfig.INTERCEPTOR_CLASSES_CONFIG, TracingConsumerInterceptor.class.getName());

Wrapping clients

The other way is by wrapping the Kafka client with a tracing enabled Kafka client.

Assuming you have a Producer<K, V> producer instance, you can wrap it in the following way.

KafkaTelemetry telemetry = KafkaTelemetry.create(GlobalOpenTelemetry.get());
Producer<String, String> tracingProducer = telemetry.wrap(producer);

Then use the tracingProducer as usual for sending messages to the Kafka cluster.

Assuming you have a Consumer<K, V> consumer instance, you can wrap it in the following way.

KafkaTelemetry telemetry = KafkaTelemetry.create(GlobalOpenTelemetry.get());
Consumer<String, String> tracingConsumer = telemetry.wrap(this.consumer);

Then use the tracingConsumer as usual for receiving messages from the Kafka cluster.

Usage (Metrics)

The Kafka client exposes metrics via org.apache.kafka.common.metrics.MetricsReporter interface. OpenTelemetry provides an implementation that bridges the metrics into OpenTelemetry.

To use, merge the config properties from KafkaTelemetry.create(OpenTelemetry).metricConfigProperties() with the configuration used when creating your producer or consumer.

Note: Kafka reports several metrics at multiple attribute granularities. For example, records-consumed-total is reported with attribute key [client-id] and [client-id, topic]. If you analyze the sum of records consumed, ignoring dimensions, backends are likely to double count. The implementation detects this scenario and only records the most granular set of attributes available. In the case of records-consumed-total, it reports [client-id, topic] and ignores [client-id].

The following table shows the full set of metrics exposed by the kafka client, and the corresponding OpenTelemetry metric each maps to (if available). Empty values in the Instrument Name, Instrument Description, etc column indicates there is no registered mapping for the metric and data is NOT collected.

Metric Group Metric Name Attribute Keys Instrument Name Instrument Description Instrument Type
app-info commit-id client-id
app-info start-time-ms client-id
app-info version client-id
consumer-coordinator-metrics assigned-partitions client-id kafka.consumer.assigned_partitions The number of partitions currently assigned to this consumer DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics commit-latency-avg client-id kafka.consumer.commit_latency_avg The average time taken for a commit request DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics commit-latency-max client-id kafka.consumer.commit_latency_max The max time taken for a commit request DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics commit-rate client-id kafka.consumer.commit_rate The number of commit calls per second DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics commit-total client-id kafka.consumer.commit_total The total number of commit calls DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics failed-rebalance-rate-per-hour client-id kafka.consumer.failed_rebalance_rate_per_hour The number of failed rebalance events per hour DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics failed-rebalance-total client-id kafka.consumer.failed_rebalance_total The total number of failed rebalance events DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics heartbeat-rate client-id kafka.consumer.heartbeat_rate The number of heartbeats per second DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics heartbeat-response-time-max client-id kafka.consumer.heartbeat_response_time_max The max time taken to receive a response to a heartbeat request DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics heartbeat-total client-id kafka.consumer.heartbeat_total The total number of heartbeats DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics join-rate client-id kafka.consumer.join_rate The number of group joins per second DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics join-time-avg client-id kafka.consumer.join_time_avg The average time taken for a group rejoin DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics join-time-max client-id kafka.consumer.join_time_max The max time taken for a group rejoin DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics join-total client-id kafka.consumer.join_total The total number of group joins DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics last-heartbeat-seconds-ago client-id kafka.consumer.last_heartbeat_seconds_ago The number of seconds since the last coordinator heartbeat was sent DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics last-rebalance-seconds-ago client-id kafka.consumer.last_rebalance_seconds_ago The number of seconds since the last successful rebalance event DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-assigned-latency-avg client-id kafka.consumer.partition_assigned_latency_avg The average time taken for a partition-assigned rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-assigned-latency-max client-id kafka.consumer.partition_assigned_latency_max The max time taken for a partition-assigned rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-lost-latency-avg client-id kafka.consumer.partition_lost_latency_avg The average time taken for a partition-lost rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-lost-latency-max client-id kafka.consumer.partition_lost_latency_max The max time taken for a partition-lost rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-revoked-latency-avg client-id kafka.consumer.partition_revoked_latency_avg The average time taken for a partition-revoked rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics partition-revoked-latency-max client-id kafka.consumer.partition_revoked_latency_max The max time taken for a partition-revoked rebalance listener callback DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics rebalance-latency-avg client-id kafka.consumer.rebalance_latency_avg The average time taken for a group to complete a successful rebalance, which may be composed of several failed re-trials until it succeeded DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics rebalance-latency-max client-id kafka.consumer.rebalance_latency_max The max time taken for a group to complete a successful rebalance, which may be composed of several failed re-trials until it succeeded DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics rebalance-latency-total client-id kafka.consumer.rebalance_latency_total The total number of milliseconds this consumer has spent in successful rebalances since creation DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics rebalance-rate-per-hour client-id kafka.consumer.rebalance_rate_per_hour The number of successful rebalance events per hour, each event is composed of several failed re-trials until it succeeded DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics rebalance-total client-id kafka.consumer.rebalance_total The total number of successful rebalance events, each event is composed of several failed re-trials until it succeeded DOUBLE_OBSERVABLE_COUNTER
consumer-coordinator-metrics sync-rate client-id kafka.consumer.sync_rate The number of group syncs per second DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics sync-time-avg client-id kafka.consumer.sync_time_avg The average time taken for a group sync DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics sync-time-max client-id kafka.consumer.sync_time_max The max time taken for a group sync DOUBLE_OBSERVABLE_GAUGE
consumer-coordinator-metrics sync-total client-id kafka.consumer.sync_total The total number of group syncs DOUBLE_OBSERVABLE_COUNTER
consumer-fetch-manager-metrics bytes-consumed-rate client-id
consumer-fetch-manager-metrics bytes-consumed-rate client-id,topic kafka.consumer.bytes_consumed_rate The average number of bytes consumed per second DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics bytes-consumed-total client-id
consumer-fetch-manager-metrics bytes-consumed-total client-id,topic kafka.consumer.bytes_consumed_total The total number of bytes consumed DOUBLE_OBSERVABLE_COUNTER
consumer-fetch-manager-metrics fetch-latency-avg client-id kafka.consumer.fetch_latency_avg The average time taken for a fetch request. DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-latency-max client-id kafka.consumer.fetch_latency_max The max time taken for any fetch request. DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-rate client-id kafka.consumer.fetch_rate The number of fetch requests per second. DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-size-avg client-id
consumer-fetch-manager-metrics fetch-size-avg client-id,topic kafka.consumer.fetch_size_avg The average number of bytes fetched per request DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-size-max client-id
consumer-fetch-manager-metrics fetch-size-max client-id,topic kafka.consumer.fetch_size_max The maximum number of bytes fetched per request DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-throttle-time-avg client-id kafka.consumer.fetch_throttle_time_avg The average throttle time in ms DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-throttle-time-max client-id kafka.consumer.fetch_throttle_time_max The maximum throttle time in ms DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics fetch-total client-id kafka.consumer.fetch_total The total number of fetch requests. DOUBLE_OBSERVABLE_COUNTER
consumer-fetch-manager-metrics preferred-read-replica client-id,topic,partition
consumer-fetch-manager-metrics records-consumed-rate client-id
consumer-fetch-manager-metrics records-consumed-rate client-id,topic kafka.consumer.records_consumed_rate The average number of records consumed per second DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-consumed-total client-id
consumer-fetch-manager-metrics records-consumed-total client-id,topic kafka.consumer.records_consumed_total The total number of records consumed DOUBLE_OBSERVABLE_COUNTER
consumer-fetch-manager-metrics records-lag client-id,topic,partition kafka.consumer.records_lag The latest lag of the partition DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-lag-avg client-id,topic,partition kafka.consumer.records_lag_avg The average lag of the partition DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-lag-max client-id
consumer-fetch-manager-metrics records-lag-max client-id,topic,partition kafka.consumer.records_lag_max The maximum lag in terms of number of records for any partition in this window DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-lead client-id,topic,partition kafka.consumer.records_lead The latest lead of the partition DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-lead-avg client-id,topic,partition kafka.consumer.records_lead_avg The average lead of the partition DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-lead-min client-id
consumer-fetch-manager-metrics records-lead-min client-id,topic,partition kafka.consumer.records_lead_min The minimum lead in terms of number of records for any partition in this window DOUBLE_OBSERVABLE_GAUGE
consumer-fetch-manager-metrics records-per-request-avg client-id
consumer-fetch-manager-metrics records-per-request-avg client-id,topic kafka.consumer.records_per_request_avg The average number of records in each request DOUBLE_OBSERVABLE_GAUGE
consumer-metrics connection-close-rate client-id kafka.consumer.connection_close_rate The number of connections closed per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics connection-close-total client-id kafka.consumer.connection_close_total The total number of connections closed DOUBLE_OBSERVABLE_COUNTER
consumer-metrics connection-count client-id kafka.consumer.connection_count The current number of active connections. DOUBLE_OBSERVABLE_GAUGE
consumer-metrics connection-creation-rate client-id kafka.consumer.connection_creation_rate The number of new connections established per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics connection-creation-total client-id kafka.consumer.connection_creation_total The total number of new connections established DOUBLE_OBSERVABLE_COUNTER
consumer-metrics failed-authentication-rate client-id kafka.consumer.failed_authentication_rate The number of connections with failed authentication per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics failed-authentication-total client-id kafka.consumer.failed_authentication_total The total number of connections with failed authentication DOUBLE_OBSERVABLE_COUNTER
consumer-metrics failed-reauthentication-rate client-id kafka.consumer.failed_reauthentication_rate The number of failed re-authentication of connections per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics failed-reauthentication-total client-id kafka.consumer.failed_reauthentication_total The total number of failed re-authentication of connections DOUBLE_OBSERVABLE_COUNTER
consumer-metrics incoming-byte-rate client-id
consumer-metrics incoming-byte-total client-id
consumer-metrics io-ratio client-id kafka.consumer.io_ratio The fraction of time the I/O thread spent doing I/O DOUBLE_OBSERVABLE_GAUGE
consumer-metrics io-time-ns-avg client-id kafka.consumer.io_time_ns_avg The average length of time for I/O per select call in nanoseconds. DOUBLE_OBSERVABLE_GAUGE
consumer-metrics io-wait-ratio client-id kafka.consumer.io_wait_ratio The fraction of time the I/O thread spent waiting DOUBLE_OBSERVABLE_GAUGE
consumer-metrics io-wait-time-ns-avg client-id kafka.consumer.io_wait_time_ns_avg The average length of time the I/O thread spent waiting for a socket ready for reads or writes in nanoseconds. DOUBLE_OBSERVABLE_GAUGE
consumer-metrics io-waittime-total client-id kafka.consumer.io_waittime_total The total time the I/O thread spent waiting DOUBLE_OBSERVABLE_COUNTER
consumer-metrics iotime-total client-id kafka.consumer.iotime_total The total time the I/O thread spent doing I/O DOUBLE_OBSERVABLE_COUNTER
consumer-metrics last-poll-seconds-ago client-id kafka.consumer.last_poll_seconds_ago The number of seconds since the last poll() invocation. DOUBLE_OBSERVABLE_GAUGE
consumer-metrics network-io-rate client-id kafka.consumer.network_io_rate The number of network operations (reads or writes) on all connections per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics network-io-total client-id kafka.consumer.network_io_total The total number of network operations (reads or writes) on all connections DOUBLE_OBSERVABLE_COUNTER
consumer-metrics outgoing-byte-rate client-id
consumer-metrics outgoing-byte-total client-id
consumer-metrics poll-idle-ratio-avg client-id kafka.consumer.poll_idle_ratio_avg The average fraction of time the consumer's poll() is idle as opposed to waiting for the user code to process records. DOUBLE_OBSERVABLE_GAUGE
consumer-metrics reauthentication-latency-avg client-id kafka.consumer.reauthentication_latency_avg The average latency observed due to re-authentication DOUBLE_OBSERVABLE_GAUGE
consumer-metrics reauthentication-latency-max client-id kafka.consumer.reauthentication_latency_max The max latency observed due to re-authentication DOUBLE_OBSERVABLE_GAUGE
consumer-metrics request-rate client-id
consumer-metrics request-size-avg client-id
consumer-metrics request-size-max client-id
consumer-metrics request-total client-id
consumer-metrics response-rate client-id
consumer-metrics response-total client-id
consumer-metrics select-rate client-id kafka.consumer.select_rate The number of times the I/O layer checked for new I/O to perform per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics select-total client-id kafka.consumer.select_total The total number of times the I/O layer checked for new I/O to perform DOUBLE_OBSERVABLE_COUNTER
consumer-metrics successful-authentication-no-reauth-total client-id kafka.consumer.successful_authentication_no_reauth_total The total number of connections with successful authentication where the client does not support re-authentication DOUBLE_OBSERVABLE_COUNTER
consumer-metrics successful-authentication-rate client-id kafka.consumer.successful_authentication_rate The number of connections with successful authentication per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics successful-authentication-total client-id kafka.consumer.successful_authentication_total The total number of connections with successful authentication DOUBLE_OBSERVABLE_COUNTER
consumer-metrics successful-reauthentication-rate client-id kafka.consumer.successful_reauthentication_rate The number of successful re-authentication of connections per second DOUBLE_OBSERVABLE_GAUGE
consumer-metrics successful-reauthentication-total client-id kafka.consumer.successful_reauthentication_total The total number of successful re-authentication of connections DOUBLE_OBSERVABLE_COUNTER
consumer-metrics time-between-poll-avg client-id kafka.consumer.time_between_poll_avg The average delay between invocations of poll(). DOUBLE_OBSERVABLE_GAUGE
consumer-metrics time-between-poll-max client-id kafka.consumer.time_between_poll_max The max delay between invocations of poll(). DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics incoming-byte-rate client-id,node-id kafka.consumer.incoming_byte_rate The number of bytes read off all sockets per second DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics incoming-byte-total client-id,node-id kafka.consumer.incoming_byte_total The total number of bytes read off all sockets DOUBLE_OBSERVABLE_COUNTER
consumer-node-metrics outgoing-byte-rate client-id,node-id kafka.consumer.outgoing_byte_rate The number of outgoing bytes sent to all servers per second DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics outgoing-byte-total client-id,node-id kafka.consumer.outgoing_byte_total The total number of outgoing bytes sent to all servers DOUBLE_OBSERVABLE_COUNTER
consumer-node-metrics request-latency-avg client-id,node-id kafka.consumer.request_latency_avg DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics request-latency-max client-id,node-id kafka.consumer.request_latency_max DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics request-rate client-id,node-id kafka.consumer.request_rate The number of requests sent per second DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics request-size-avg client-id,node-id kafka.consumer.request_size_avg The average size of requests sent. DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics request-size-max client-id,node-id kafka.consumer.request_size_max The maximum size of any request sent. DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics request-total client-id,node-id kafka.consumer.request_total The total number of requests sent DOUBLE_OBSERVABLE_COUNTER
consumer-node-metrics response-rate client-id,node-id kafka.consumer.response_rate The number of responses received per second DOUBLE_OBSERVABLE_GAUGE
consumer-node-metrics response-total client-id,node-id kafka.consumer.response_total The total number of responses received DOUBLE_OBSERVABLE_COUNTER
kafka-metrics-count count client-id
producer-metrics batch-size-avg client-id kafka.producer.batch_size_avg The average number of bytes sent per partition per-request. DOUBLE_OBSERVABLE_GAUGE
producer-metrics batch-size-max client-id kafka.producer.batch_size_max The max number of bytes sent per partition per-request. DOUBLE_OBSERVABLE_GAUGE
producer-metrics batch-split-rate client-id kafka.producer.batch_split_rate The average number of batch splits per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics batch-split-total client-id kafka.producer.batch_split_total The total number of batch splits DOUBLE_OBSERVABLE_COUNTER
producer-metrics buffer-available-bytes client-id kafka.producer.buffer_available_bytes The total amount of buffer memory that is not being used (either unallocated or in the free list). DOUBLE_OBSERVABLE_GAUGE
producer-metrics buffer-exhausted-rate client-id kafka.producer.buffer_exhausted_rate The average per-second number of record sends that are dropped due to buffer exhaustion DOUBLE_OBSERVABLE_GAUGE
producer-metrics buffer-exhausted-total client-id kafka.producer.buffer_exhausted_total The total number of record sends that are dropped due to buffer exhaustion DOUBLE_OBSERVABLE_COUNTER
producer-metrics buffer-total-bytes client-id kafka.producer.buffer_total_bytes The maximum amount of buffer memory the client can use (whether or not it is currently used). DOUBLE_OBSERVABLE_GAUGE
producer-metrics bufferpool-wait-ratio client-id kafka.producer.bufferpool_wait_ratio The fraction of time an appender waits for space allocation. DOUBLE_OBSERVABLE_GAUGE
producer-metrics bufferpool-wait-time-total client-id kafka.producer.bufferpool_wait_time_total The total time an appender waits for space allocation. DOUBLE_OBSERVABLE_COUNTER
producer-metrics compression-rate-avg client-id kafka.producer.compression_rate_avg The average compression rate of record batches. DOUBLE_OBSERVABLE_GAUGE
producer-metrics connection-close-rate client-id kafka.producer.connection_close_rate The number of connections closed per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics connection-close-total client-id kafka.producer.connection_close_total The total number of connections closed DOUBLE_OBSERVABLE_COUNTER
producer-metrics connection-count client-id kafka.producer.connection_count The current number of active connections. DOUBLE_OBSERVABLE_GAUGE
producer-metrics connection-creation-rate client-id kafka.producer.connection_creation_rate The number of new connections established per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics connection-creation-total client-id kafka.producer.connection_creation_total The total number of new connections established DOUBLE_OBSERVABLE_COUNTER
producer-metrics failed-authentication-rate client-id kafka.producer.failed_authentication_rate The number of connections with failed authentication per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics failed-authentication-total client-id kafka.producer.failed_authentication_total The total number of connections with failed authentication DOUBLE_OBSERVABLE_COUNTER
producer-metrics failed-reauthentication-rate client-id kafka.producer.failed_reauthentication_rate The number of failed re-authentication of connections per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics failed-reauthentication-total client-id kafka.producer.failed_reauthentication_total The total number of failed re-authentication of connections DOUBLE_OBSERVABLE_COUNTER
producer-metrics incoming-byte-rate client-id
producer-metrics incoming-byte-total client-id
producer-metrics io-ratio client-id kafka.producer.io_ratio The fraction of time the I/O thread spent doing I/O DOUBLE_OBSERVABLE_GAUGE
producer-metrics io-time-ns-avg client-id kafka.producer.io_time_ns_avg The average length of time for I/O per select call in nanoseconds. DOUBLE_OBSERVABLE_GAUGE
producer-metrics io-wait-ratio client-id kafka.producer.io_wait_ratio The fraction of time the I/O thread spent waiting DOUBLE_OBSERVABLE_GAUGE
producer-metrics io-wait-time-ns-avg client-id kafka.producer.io_wait_time_ns_avg The average length of time the I/O thread spent waiting for a socket ready for reads or writes in nanoseconds. DOUBLE_OBSERVABLE_GAUGE
producer-metrics io-waittime-total client-id kafka.producer.io_waittime_total The total time the I/O thread spent waiting DOUBLE_OBSERVABLE_COUNTER
producer-metrics iotime-total client-id kafka.producer.iotime_total The total time the I/O thread spent doing I/O DOUBLE_OBSERVABLE_COUNTER
producer-metrics metadata-age client-id kafka.producer.metadata_age The age in seconds of the current producer metadata being used. DOUBLE_OBSERVABLE_GAUGE
producer-metrics network-io-rate client-id kafka.producer.network_io_rate The number of network operations (reads or writes) on all connections per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics network-io-total client-id kafka.producer.network_io_total The total number of network operations (reads or writes) on all connections DOUBLE_OBSERVABLE_COUNTER
producer-metrics outgoing-byte-rate client-id
producer-metrics outgoing-byte-total client-id
producer-metrics produce-throttle-time-avg client-id kafka.producer.produce_throttle_time_avg The average time in ms a request was throttled by a broker DOUBLE_OBSERVABLE_GAUGE
producer-metrics produce-throttle-time-max client-id kafka.producer.produce_throttle_time_max The maximum time in ms a request was throttled by a broker DOUBLE_OBSERVABLE_GAUGE
producer-metrics reauthentication-latency-avg client-id kafka.producer.reauthentication_latency_avg The average latency observed due to re-authentication DOUBLE_OBSERVABLE_GAUGE
producer-metrics reauthentication-latency-max client-id kafka.producer.reauthentication_latency_max The max latency observed due to re-authentication DOUBLE_OBSERVABLE_GAUGE
producer-metrics record-error-rate client-id
producer-metrics record-error-total client-id
producer-metrics record-queue-time-avg client-id kafka.producer.record_queue_time_avg The average time in ms record batches spent in the send buffer. DOUBLE_OBSERVABLE_GAUGE
producer-metrics record-queue-time-max client-id kafka.producer.record_queue_time_max The maximum time in ms record batches spent in the send buffer. DOUBLE_OBSERVABLE_GAUGE
producer-metrics record-retry-rate client-id
producer-metrics record-retry-total client-id
producer-metrics record-send-rate client-id
producer-metrics record-send-total client-id
producer-metrics record-size-avg client-id kafka.producer.record_size_avg The average record size DOUBLE_OBSERVABLE_GAUGE
producer-metrics record-size-max client-id kafka.producer.record_size_max The maximum record size DOUBLE_OBSERVABLE_GAUGE
producer-metrics records-per-request-avg client-id kafka.producer.records_per_request_avg The average number of records per request. DOUBLE_OBSERVABLE_GAUGE
producer-metrics request-latency-avg client-id
producer-metrics request-latency-max client-id
producer-metrics request-rate client-id
producer-metrics request-size-avg client-id
producer-metrics request-size-max client-id
producer-metrics request-total client-id
producer-metrics requests-in-flight client-id kafka.producer.requests_in_flight The current number of in-flight requests awaiting a response. DOUBLE_OBSERVABLE_GAUGE
producer-metrics response-rate client-id
producer-metrics response-total client-id
producer-metrics select-rate client-id kafka.producer.select_rate The number of times the I/O layer checked for new I/O to perform per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics select-total client-id kafka.producer.select_total The total number of times the I/O layer checked for new I/O to perform DOUBLE_OBSERVABLE_COUNTER
producer-metrics successful-authentication-no-reauth-total client-id kafka.producer.successful_authentication_no_reauth_total The total number of connections with successful authentication where the client does not support re-authentication DOUBLE_OBSERVABLE_COUNTER
producer-metrics successful-authentication-rate client-id kafka.producer.successful_authentication_rate The number of connections with successful authentication per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics successful-authentication-total client-id kafka.producer.successful_authentication_total The total number of connections with successful authentication DOUBLE_OBSERVABLE_COUNTER
producer-metrics successful-reauthentication-rate client-id kafka.producer.successful_reauthentication_rate The number of successful re-authentication of connections per second DOUBLE_OBSERVABLE_GAUGE
producer-metrics successful-reauthentication-total client-id kafka.producer.successful_reauthentication_total The total number of successful re-authentication of connections DOUBLE_OBSERVABLE_COUNTER
producer-metrics waiting-threads client-id kafka.producer.waiting_threads The number of user threads blocked waiting for buffer memory to enqueue their records DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics incoming-byte-rate client-id,node-id kafka.producer.incoming_byte_rate The number of bytes read off all sockets per second DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics incoming-byte-total client-id,node-id kafka.producer.incoming_byte_total The total number of bytes read off all sockets DOUBLE_OBSERVABLE_COUNTER
producer-node-metrics outgoing-byte-rate client-id,node-id kafka.producer.outgoing_byte_rate The number of outgoing bytes sent to all servers per second DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics outgoing-byte-total client-id,node-id kafka.producer.outgoing_byte_total The total number of outgoing bytes sent to all servers DOUBLE_OBSERVABLE_COUNTER
producer-node-metrics request-latency-avg client-id,node-id kafka.producer.request_latency_avg The average request latency in ms DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics request-latency-max client-id,node-id kafka.producer.request_latency_max The maximum request latency in ms DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics request-rate client-id,node-id kafka.producer.request_rate The number of requests sent per second DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics request-size-avg client-id,node-id kafka.producer.request_size_avg The average size of requests sent. DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics request-size-max client-id,node-id kafka.producer.request_size_max The maximum size of any request sent. DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics request-total client-id,node-id kafka.producer.request_total The total number of requests sent DOUBLE_OBSERVABLE_COUNTER
producer-node-metrics response-rate client-id,node-id kafka.producer.response_rate The number of responses received per second DOUBLE_OBSERVABLE_GAUGE
producer-node-metrics response-total client-id,node-id kafka.producer.response_total The total number of responses received DOUBLE_OBSERVABLE_COUNTER
producer-topic-metrics byte-rate client-id,topic kafka.producer.byte_rate The average number of bytes sent per second for a topic. DOUBLE_OBSERVABLE_GAUGE
producer-topic-metrics byte-total client-id,topic kafka.producer.byte_total The total number of bytes sent for a topic. DOUBLE_OBSERVABLE_COUNTER
producer-topic-metrics compression-rate client-id,topic kafka.producer.compression_rate The average compression rate of record batches for a topic. DOUBLE_OBSERVABLE_GAUGE
producer-topic-metrics record-error-rate client-id,topic kafka.producer.record_error_rate The average per-second number of record sends that resulted in errors DOUBLE_OBSERVABLE_GAUGE
producer-topic-metrics record-error-total client-id,topic kafka.producer.record_error_total The total number of record sends that resulted in errors DOUBLE_OBSERVABLE_COUNTER
producer-topic-metrics record-retry-rate client-id,topic kafka.producer.record_retry_rate The average per-second number of retried record sends DOUBLE_OBSERVABLE_GAUGE
producer-topic-metrics record-retry-total client-id,topic kafka.producer.record_retry_total The total number of retried record sends DOUBLE_OBSERVABLE_COUNTER
producer-topic-metrics record-send-rate client-id,topic kafka.producer.record_send_rate The average number of records sent per second. DOUBLE_OBSERVABLE_GAUGE
producer-topic-metrics record-send-total client-id,topic kafka.producer.record_send_total The total number of records sent. DOUBLE_OBSERVABLE_COUNTER