-
Notifications
You must be signed in to change notification settings - Fork 138
/
Copy pathTracingConfiguration.java
121 lines (103 loc) · 4.61 KB
/
TracingConfiguration.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
package brave.example;
import brave.Tracing;
import brave.baggage.BaggageField;
import brave.baggage.BaggagePropagation;
import brave.baggage.BaggagePropagationConfig;
import brave.baggage.CorrelationScopeConfig;
import brave.context.log4j12.MDCScopeDecorator;
import brave.grpc.GrpcTracing;
import brave.http.HttpTracing;
import brave.netty.http.NettyHttpTracing;
import brave.propagation.B3Propagation;
import brave.propagation.CurrentTraceContext;
import brave.propagation.CurrentTraceContext.ScopeDecorator;
import brave.propagation.Propagation;
import brave.propagation.ThreadLocalCurrentTraceContext;
import brave.rpc.RpcTracing;
import io.grpc.ClientInterceptor;
import io.grpc.ServerInterceptor;
import io.netty.channel.ChannelHandler;
import java.io.IOException;
import java.util.logging.Logger;
import zipkin2.reporter.BytesMessageSender;
import zipkin2.reporter.brave.AsyncZipkinSpanHandler;
import zipkin2.reporter.urlconnection.URLConnectionSender;
final class TracingConfiguration {
final HttpTracing httpTracing;
final RpcTracing rpcTracing;
static TracingConfiguration create(String defaultServiceName) {
Tracing tracing = TracingFactory.create(defaultServiceName);
return new TracingConfiguration(HttpTracing.create(tracing), RpcTracing.create(tracing));
}
TracingConfiguration(HttpTracing httpTracing, RpcTracing rpcTracing) {
this.httpTracing = httpTracing;
this.rpcTracing = rpcTracing;
}
public ChannelHandler serverHandler() {
return NettyHttpTracing.create(httpTracing).serverHandler();
}
public ClientInterceptor clientInterceptor() {
// TODO: RpcTracing.clientOf("backend") equivalent
return GrpcTracing.create(rpcTracing).newClientInterceptor();
}
public ServerInterceptor serverInterceptor() {
return GrpcTracing.create(rpcTracing).newServerInterceptor();
}
static final class TracingFactory {
static final BaggageField USER_NAME = BaggageField.create("userName");
/** Decides how to name and tag spans. By default they are named the same as the http method. */
static Tracing create(String serviceName) {
return tracing(System.getProperty("brave.localServiceName", serviceName));
}
/** Controls aspects of tracing such as the service name that shows up in the UI */
static Tracing tracing(String serviceName) {
return Tracing.newBuilder()
.localServiceName(serviceName)
.supportsJoin(Boolean.parseBoolean(System.getProperty("brave.supportsJoin", "true")))
.supportsJoin(Boolean.parseBoolean(System.getProperty("brave.traceId128Bit", "false")))
.propagationFactory(propagationFactory())
.currentTraceContext(currentTraceContext(correlationScopeDecorator()))
.addSpanHandler(spanHandler(sender()))
.build();
}
/** Allows log patterns to use {@code %{traceId}} {@code %{spanId}} and {@code %{userName}} */
static ScopeDecorator correlationScopeDecorator() {
return MDCScopeDecorator.newBuilder()
.add(CorrelationScopeConfig.SingleCorrelationField.create(USER_NAME)).build();
}
/** Propagates trace context between threads. */
static CurrentTraceContext currentTraceContext(ScopeDecorator correlationScopeDecorator) {
return ThreadLocalCurrentTraceContext.newBuilder()
.addScopeDecorator(correlationScopeDecorator)
.build();
}
/** Configures propagation for {@link #USER_NAME}, using the remote header "user_name" */
static Propagation.Factory propagationFactory() {
return BaggagePropagation.newFactoryBuilder(B3Propagation.FACTORY)
.add(BaggagePropagationConfig.SingleBaggageField.newBuilder(USER_NAME)
.addKeyName("user_name")
.build())
.build();
}
/** Configuration for how to send spans to Zipkin */
static BytesMessageSender sender() {
return URLConnectionSender.create(
System.getProperty("zipkin.baseUrl", "http://127.0.0.1:9411") + "/api/v2/spans");
}
/** Configuration for how to buffer spans into messages for Zipkin */
static AsyncZipkinSpanHandler spanHandler(BytesMessageSender sender) {
final AsyncZipkinSpanHandler spanHandler = AsyncZipkinSpanHandler.create(sender);
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
spanHandler.close(); // Make sure spans are reported on shutdown
try {
sender.close(); // Release any network resources used to send spans
} catch (IOException e) {
Logger.getAnonymousLogger().warning("error closing trace sender: " + e.getMessage());
}
}));
return spanHandler;
}
private TracingFactory() {
}
}
}