@Override public boolean isSampled(Span span) { if (span instanceof SpanWrapper) { span = ((SpanWrapper) span).unwrap(Span.class); } if (span instanceof io.jaegertracing.internal.JaegerSpan) { final io.jaegertracing.internal.JaegerSpan jaegerSpan = (io.jaegertracing.internal.JaegerSpan) span; return jaegerSpan.context().isSampled(); } return false; } }
@Override public boolean isRoot(Span span) { // TODO replace with Span#unwrap once https://github.com/opentracing/opentracing-java/pull/211 is merged if (span instanceof SpanWrapper) { span = ((SpanWrapper) span).getDelegate(); } if (span instanceof io.jaegertracing.internal.JaegerSpan) { final io.jaegertracing.internal.JaegerSpan jaegerSpan = (io.jaegertracing.internal.JaegerSpan) span; return jaegerSpan.context().getParentId() == 0; } return false; }
private void logFields(JaegerSpan jaegerSpan, String key, String value, String prevItem, boolean truncated, boolean valid) { if (!jaegerSpan.context().isSampled()) { return; } Map<String, String> fields = new HashMap<String, String>(); fields.put("event", "baggage"); fields.put("key", key); fields.put("value", value); if (prevItem != null) { fields.put("override", "true"); } if (truncated) { fields.put("truncated", "true"); } if (!valid) { fields.put("invalid", "true"); } jaegerSpan.log(fields); } }
@Override public boolean isRoot(Span span) { // TODO replace with Span#unwrap once https://github.com/opentracing/opentracing-java/pull/211 is merged if (span instanceof SpanWrapper) { span = ((SpanWrapper) span).getDelegate(); } if (span instanceof io.jaegertracing.internal.JaegerSpan) { final io.jaegertracing.internal.JaegerSpan jaegerSpan = (io.jaegertracing.internal.JaegerSpan) span; return jaegerSpan.context().getParentId() == 0; } return false; }
@Override public boolean isSampled(Span span) { if (span instanceof SpanWrapper) { span = ((SpanWrapper) span).unwrap(Span.class); } if (span instanceof io.jaegertracing.internal.JaegerSpan) { final io.jaegertracing.internal.JaegerSpan jaegerSpan = (io.jaegertracing.internal.JaegerSpan) span; return jaegerSpan.context().isSampled(); } return false; } }
metrics.baggageUpdateFailure.inc(1); logFields(jaegerSpan, key, value, prevItem, truncated, restriction.isKeyAllowed()); return jaegerSpan.context(); logFields(jaegerSpan, key, value, prevItem, truncated, restriction.isKeyAllowed()); metrics.baggageUpdateSuccess.inc(1); return jaegerSpan.context().withBaggageItem(key, value);
public static io.jaegertracing.thriftjava.Span convertSpan(JaegerSpan jaegerSpan) { JaegerSpanContext context = jaegerSpan.context(); boolean oneChildOfParent = jaegerSpan.getReferences().size() == 1 && References.CHILD_OF.equals(jaegerSpan.getReferences().get(0).getType()); List<SpanRef> references = oneChildOfParent ? Collections.<SpanRef>emptyList() : buildReferences(jaegerSpan.getReferences()); return new io.jaegertracing.thriftjava.Span( context.getTraceIdLow(), context.getTraceIdHigh(), context.getSpanId(), oneChildOfParent ? context.getParentId() : 0, jaegerSpan.getOperationName(), context.getFlags(), jaegerSpan.getStart(), jaegerSpan.getDuration() ) .setReferences(references) .setTags(buildTags(jaegerSpan.getTags())) .setLogs(buildLogs(jaegerSpan.getLogs())); }