
com.github.kristofa.brave.ThreadLocalServerAndClientSpanState Maven / Gradle / Ivy
package com.github.kristofa.brave;
import com.github.kristofa.brave.internal.Util;
import com.twitter.zipkin.gen.Endpoint;
import com.twitter.zipkin.gen.Span;
import java.net.InetAddress;
/**
* {@link ServerAndClientSpanState} implementation that keeps trace state using a ThreadLocal variable.
*
* @author kristof
*/
final class ThreadLocalServerAndClientSpanState implements ServerAndClientSpanState {
private final static ThreadLocal currentServerSpan = new ThreadLocal() {
@Override
protected ServerSpan initialValue() {
return ServerSpan.create(null);
}
};
private final static ThreadLocal currentClientSpan = new ThreadLocal<>();
private final static ThreadLocal currentClientServiceName = new ThreadLocal<>();
private final Endpoint endpoint;
/**
* Constructor
*
* @param ip InetAddress of current host. If you don't have access to InetAddress you can use InetAddressUtilities#getLocalHostLANAddress()
* @param port port on which current process is listening.
* @param serviceName Name of the local service being traced. Should be lowercase and not null
or empty.
* @deprecated Please switch to constructor that takes 'int' for ip. This only does a conversion from the InetAddress to integer anyway
* and using InetAddress can result in ns lookup and nasty side effects.
*/
@Deprecated
public ThreadLocalServerAndClientSpanState(InetAddress ip, int port, String serviceName) {
Util.checkNotNull(ip, "ip address must be specified.");
Util.checkNotBlank(serviceName, "Service name must be specified.");
endpoint = new Endpoint(InetAddressUtilities.toInt(ip), (short) port, serviceName);
}
/**
* Constructor
*
* @param ip Int representation of ipv4 address.
* @param port port on which current process is listening.
* @param serviceName Name of the local service being traced. Should be lowercase and not null
or empty.
*/
public ThreadLocalServerAndClientSpanState(int ip, int port, String serviceName) {
Util.checkNotNull(ip, "ip address must be specified.");
Util.checkNotBlank(serviceName, "Service name must be specified.");
endpoint = new Endpoint(ip, (short) port, serviceName);
}
/**
* {@inheritDoc}
*/
@Override
public ServerSpan getCurrentServerSpan() {
return currentServerSpan.get();
}
@Override
public Endpoint getServerEndpoint() {
return endpoint;
}
/**
* {@inheritDoc}
*/
@Override
public void setCurrentServerSpan(final ServerSpan span) {
if (span == null) {
currentServerSpan.remove();
} else {
currentServerSpan.set(span);
}
}
/**
* {@inheritDoc}
*/
@Override
public Endpoint getClientEndpoint() {
final String serviceName = currentClientServiceName.get();
if (serviceName == null) {
return endpoint;
} else {
final Endpoint ep = new Endpoint(endpoint);
ep.setService_name(serviceName);
return ep;
}
}
/**
* {@inheritDoc}
*/
@Override
public Span getCurrentClientSpan() {
return currentClientSpan.get();
}
/**
* {@inheritDoc}
*/
@Override
public void setCurrentClientSpan(final Span span) {
currentClientSpan.set(span);
}
@Override
public void setCurrentClientServiceName(final String serviceName) {
currentClientServiceName.set(serviceName);
}
@Override
public Boolean sample() {
return currentServerSpan.get().getSample();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy