All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.kristofa.brave.ClientSpanThreadBinder Maven / Gradle / Ivy

package com.github.kristofa.brave;

import com.twitter.zipkin.gen.Span;

import static com.github.kristofa.brave.internal.Util.checkNotNull;

/**
 * Allows binding span from client request thread to a async callback thread that process the result.
 * 

* To be used for async client call the result of which is processed in a separate callback thread. * After calling {@link ClientTracer#startNewSpan(String)}, call getCurrentClientSpan() and save the result to pass to the * callback method (e.g., local final variable) * In the callback method, call {@link #setCurrentSpan} before calling {@link com.github.kristofa.brave.ClientTracer#setClientReceived()} * @author hzhao on 8/11/14. */ public final class ClientSpanThreadBinder { private final ClientSpanState state; /** * Creates a new instance. * * @param state client span state, should not be null */ public ClientSpanThreadBinder(ClientSpanState state) { this.state = checkNotNull(state, "state"); } /** * This should be called in the thread in which the client request made after starting new client span. *

* It returns the current client span which you can keep and bind to the callback thread * @see #setCurrentSpan(Span) * @return Returned Span can be bound to different callback thread. */ public Span getCurrentClientSpan() { return state.getCurrentClientSpan(); } /** * Binds given span to current thread. This should typically be called when code is invoked in async client callback * before the {@link ClientTracer#setClientReceived()} * * @param span Span to bind to current execution thread. Should not be null. */ public void setCurrentSpan(Span span) { state.setCurrentClientSpan(span); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy