io.opentelemetry.instrumentation.rocketmqclient.v4_8.RocketMqConsumerExperimentalAttributeExtractor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of opentelemetry-rocketmq-client-4.8 Show documentation
Show all versions of opentelemetry-rocketmq-client-4.8 Show documentation
Instrumentation of Java libraries using OpenTelemetry.
The newest version!
/*
* Copyright The OpenTelemetry Authors
* SPDX-License-Identifier: Apache-2.0
*/
package io.opentelemetry.instrumentation.rocketmqclient.v4_8;
import io.opentelemetry.api.common.AttributeKey;
import io.opentelemetry.api.common.AttributesBuilder;
import io.opentelemetry.context.Context;
import io.opentelemetry.instrumentation.api.instrumenter.AttributesExtractor;
import java.net.SocketAddress;
import javax.annotation.Nullable;
import org.apache.rocketmq.common.message.MessageExt;
enum RocketMqConsumerExperimentalAttributeExtractor
implements AttributesExtractor {
INSTANCE;
// copied from MessagingIncubatingAttributes
private static final AttributeKey MESSAGING_ROCKETMQ_MESSAGE_TAG =
AttributeKey.stringKey("messaging.rocketmq.message.tag");
private static final AttributeKey MESSAGING_ROCKETMQ_QUEUE_ID =
AttributeKey.longKey("messaging.rocketmq.queue_id");
private static final AttributeKey MESSAGING_ROCKETMQ_QUEUE_OFFSET =
AttributeKey.longKey("messaging.rocketmq.queue_offset");
private static final AttributeKey MESSAGING_ROCKETMQ_BROKER_ADDRESS =
AttributeKey.stringKey("messaging.rocketmq.broker_address");
@Override
public void onStart(AttributesBuilder attributes, Context parentContext, MessageExt msg) {
String tags = msg.getTags();
if (tags != null) {
attributes.put(MESSAGING_ROCKETMQ_MESSAGE_TAG, tags);
}
attributes.put(MESSAGING_ROCKETMQ_QUEUE_ID, msg.getQueueId());
attributes.put(MESSAGING_ROCKETMQ_QUEUE_OFFSET, msg.getQueueOffset());
SocketAddress storeHost = msg.getStoreHost();
if (storeHost != null) {
attributes.put(MESSAGING_ROCKETMQ_BROKER_ADDRESS, getBrokerHost(storeHost));
}
}
private static String getBrokerHost(SocketAddress storeHost) {
return storeHost.toString().replace("/", "");
}
@Override
public void onEnd(
AttributesBuilder attributes,
Context context,
MessageExt consumeMessageContext,
@Nullable Void unused,
@Nullable Throwable error) {}
}