
io.vertx.tracing.opentracing.OpenTracingTracer Maven / Gradle / Ivy
package io.vertx.tracing.opentracing;
import static io.vertx.tracing.opentracing.OpenTracingUtil.ACTIVE_SPAN;
import io.jaegertracing.Configuration;
import io.opentracing.Span;
import io.opentracing.SpanContext;
import io.opentracing.Tracer;
import io.opentracing.log.Fields;
import io.opentracing.propagation.Format;
import io.opentracing.propagation.TextMap;
import io.opentracing.tag.Tags;
import io.vertx.core.Context;
import io.vertx.core.spi.tracing.TagExtractor;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.function.BiConsumer;
/**
* - https://github.com/opentracing/specification/blob/master/semantic_conventions.md
* - https://github.com/opentracing/specification/blob/master/specification.md
*/
public class OpenTracingTracer implements io.vertx.core.spi.tracing.VertxTracer {
/**
* Instantiate an OpenTracing tracer configured from ENV, e.g {@code JAEGER_SERVICE_NAME}, etc...
*/
static Tracer createDefaultTracer() {
Configuration config = Configuration.fromEnv();
return config.getTracerBuilder().build();
}
private final boolean closeTracer;
private final Tracer tracer;
/**
* Instantiate a OpenTracing tracer using the specified {@code tracer}.
*
* @param closeTracer close the tracer when necessary
* @param tracer the tracer instance
*/
public OpenTracingTracer(boolean closeTracer, Tracer tracer) {
this.closeTracer = closeTracer;
this.tracer = tracer;
}
@Override
public Span receiveRequest(Context context, R request, String operation,
Iterable> headers, TagExtractor tagExtractor) {
SpanContext sc = tracer.extract(Format.Builtin.HTTP_HEADERS, new TextMap() {
@Override
public Iterator> iterator() {
return headers.iterator();
}
@Override
public void put(String key, String value) {
throw new UnsupportedOperationException();
}
});
Span span = tracer.buildSpan(operation)
.ignoreActiveSpan()
.asChildOf(sc)
.withTag(Tags.SPAN_KIND.getKey(), Tags.SPAN_KIND_SERVER)
.withTag(Tags.COMPONENT.getKey(), "vertx")
.start();
reportTags(span, request, tagExtractor);
context.putLocal(ACTIVE_SPAN, span);
return span;
}
@Override
public void sendResponse(
Context context, R response, Span span, Throwable failure, TagExtractor tagExtractor) {
if (span != null) {
context.removeLocal(ACTIVE_SPAN);
if (failure != null) {
reportFailure(span, failure);
}
reportTags(span, response, tagExtractor);
span.finish();
}
}
@Override
public Span sendRequest(Context context, R request, String operation,
BiConsumer headers, TagExtractor tagExtractor) {
Span active = context.getLocal(ACTIVE_SPAN);
if (active != null) {
Span span = tracer
.buildSpan(operation)
.asChildOf(active)
.withTag(Tags.SPAN_KIND.getKey(), Tags.SPAN_KIND_CLIENT)
.withTag(Tags.COMPONENT.getKey(), "vertx")
.start();
reportTags(span, request, tagExtractor);
if (headers != null) {
tracer.inject(span.context(), Format.Builtin.HTTP_HEADERS, new TextMap() {
@Override
public Iterator> iterator() {
throw new UnsupportedOperationException();
}
@Override
public void put(String key, String value) {
headers.accept(key, value);
}
});
}
return span;
}
return null;
}
@Override
public void receiveResponse(Context context, R response, Span span, Throwable failure,
TagExtractor tagExtractor) {
if (span != null) {
if (failure != null) {
reportFailure(span, failure);
}
reportTags(span, response, tagExtractor);
span.finish();
}
}
private void reportTags(Span span, T obj, TagExtractor tagExtractor) {
int len = tagExtractor.len(obj);
for (int idx = 0; idx < len; idx++) {
span.setTag(tagExtractor.name(obj, idx), tagExtractor.value(obj, idx));
}
}
private void reportFailure(Span span, Throwable failure) {
if (failure != null) {
span.setTag("error", true);
HashMap fields = new HashMap<>();
fields.put(Fields.EVENT, "error");
fields.put(Fields.MESSAGE, failure.getMessage());
fields.put(Fields.ERROR_KIND, "Exception");
fields.put(Fields.ERROR_OBJECT, failure);
span.log(fields);
}
}
@Override
public void close() {
if (closeTracer && tracer != null) {
tracer.close();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy