fun.fengwk.convention4j.tracer.util.TracerUtils Maven / Gradle / Ivy
package fun.fengwk.convention4j.tracer.util;
import fun.fengwk.convention4j.common.clock.SystemClock;
import fun.fengwk.convention4j.common.json.JsonUtils;
import fun.fengwk.convention4j.common.lang.StringUtils;
import fun.fengwk.convention4j.common.reflect.TypeToken;
import fun.fengwk.convention4j.common.util.LazyServiceLoader;
import fun.fengwk.convention4j.common.util.ListUtils;
import fun.fengwk.convention4j.common.util.NullSafe;
import fun.fengwk.convention4j.common.util.OrderedObject;
import fun.fengwk.convention4j.common.web.UriUtils;
import fun.fengwk.convention4j.tracer.Reference;
import fun.fengwk.convention4j.tracer.TracerImpl;
import fun.fengwk.convention4j.tracer.finisher.SpanFinisher;
import fun.fengwk.convention4j.tracer.propagation.TracerTransformer;
import fun.fengwk.convention4j.tracer.scope.ConventionScopeManager;
import io.opentracing.References;
import io.opentracing.Span;
import io.opentracing.SpanContext;
import io.opentracing.Tracer;
import io.opentracing.tag.Tags;
import io.opentracing.util.GlobalTracer;
import lombok.extern.slf4j.Slf4j;
import org.slf4j.MDC;
import java.util.*;
import java.util.stream.Collectors;
/**
* @author fengwk
*/
@Slf4j
public class TracerUtils {
private static final List SPAN_INITIALIZERS
= LazyServiceLoader.loadServiceIgnoreLoadFailed(SpanInitializer.class);
public static final String TRACE_ID = "traceId";
public static final String SPAN_ID = "spanId";
public static final String TAG_SPAN_ALIAS = "span.alias";
private TracerUtils() {}
public static void initializeGlobalTracer(SpanFinisher finisher) {
TracerTransformer tracerTransformer = new TracerTransformer();
List scopeManagers = LazyServiceLoader
.loadServiceIgnoreLoadFailed(ConventionScopeManager.class);
scopeManagers = OrderedObject.sort(scopeManagers);
ConventionScopeManager priorityScopeManager = ListUtils.getFirst(scopeManagers);
TracerImpl tracer = new TracerImpl(new SystemClock(), priorityScopeManager, tracerTransformer, finisher);
GlobalTracer.registerIfAbsent(tracer);
}
public static void initializeRootSpan(Span span) {
for (SpanInitializer initializer : SPAN_INITIALIZERS) {
initializer.initializeRootSpan(span);
}
}
public static void initializeSpan(Span span) {
for (SpanInitializer initializer : SPAN_INITIALIZERS) {
initializer.initializeSpan(span);
}
}
public static Map buildBaggage(Iterable> baggageIt) {
Map baggage = new HashMap<>();
if (baggageIt != null) {
for (Map.Entry entry : baggageIt) {
baggage.put(entry.getKey(), entry.getValue());
}
}
return baggage;
}
public static String serializeHttpPropagationBaggage(Iterable> baggageIt) {
Map baggage = buildBaggage(baggageIt);
String baggageJson = JsonUtils.toJson(baggage);
return UriUtils.encodeUriComponent(baggageJson);
}
public static Map deserializeHttpPropagationBaggage(String serializedBaggage) {
String baggageJson = UriUtils.decodeUriComponent(serializedBaggage);
return JsonUtils.fromJson(baggageJson, new TypeToken<>() {});
}
public static Reference getChildOfReference(List references) {
if (references == null || references.isEmpty()) {
return null;
}
return references.stream()
.filter(ref -> Objects.equals(ref.getReferenceType(), References.CHILD_OF))
.findFirst()
.orElse(null);
}
public static List getFollowsFromReferences(List references) {
if (references == null || references.isEmpty()) {
return Collections.emptyList();
}
return references.stream()
.filter(ref -> Objects.equals(ref.getReferenceType(), References.FOLLOWS_FROM))
.collect(Collectors.toList());
}
public static String generateTraceId() {
return generateUUID();
}
public static String generateSpanId() {
return generateUUID();
}
private static String generateUUID() {
return UUID.randomUUID().toString().replace("-", "");
}
public static Map setMDC(SpanContext spanContext) {
Map storeMdc = new HashMap<>();
storeMdc.put(TRACE_ID, MDC.get(TRACE_ID));
storeMdc.put(SPAN_ID, MDC.get(SPAN_ID));
if (spanContext != null) {
MDC.put(TRACE_ID, spanContext.toTraceId());
MDC.put(SPAN_ID, spanContext.toSpanId());
}
return storeMdc;
}
public static void clearMDC(Map storeMdc) {
String storeTraceId = storeMdc.get(TRACE_ID);
String storeSpanId = storeMdc.get(SPAN_ID);
if (StringUtils.isBlank(storeTraceId)) {
MDC.remove(TRACE_ID);
} else {
MDC.put(TRACE_ID, storeTraceId);
}
if (StringUtils.isBlank(storeSpanId)) {
MDC.remove(SPAN_ID);
} else {
MDC.put(SPAN_ID, storeSpanId);
}
}
public static Span startSpan(SpanInfo spanInfo) {
Tracer tracer = GlobalTracer.get();
Span activeSpan = tracer.activeSpan();
SpanContext parentSpanContext = NullSafe.map(activeSpan, Span::context);
if (StringUtils.isBlank(spanInfo.getOperationName())) {
log.warn("Start span failed, operation name is blank, spanInfo: {}", spanInfo);
return null;
}
String alias = spanInfo.getOperationName();
if (StringUtils.isNotBlank(spanInfo.getAlias())) {
alias = spanInfo.getAlias();
}
if (parentSpanContext == null) {
switch (spanInfo.getPropagation()) {
case REQUIRED:
break;
case SUPPORTS:
return null;
default:
throw new IllegalStateException("Unsupported span propagation: " + spanInfo.getPropagation());
}
}
Tracer.SpanBuilder spanBuilder = tracer.buildSpan(spanInfo.getOperationName())
.withTag(TracerUtils.TAG_SPAN_ALIAS, alias);
if (StringUtils.isNotBlank(spanInfo.getKind())) {
spanBuilder.withTag(Tags.SPAN_KIND, spanInfo.getKind());
}
if (parentSpanContext != null) {
spanBuilder.asChildOf(parentSpanContext);
}
return spanBuilder.start();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy