0

我是 OpenTracing 的新手。到目前为止,我主要从事房屋追踪工具的工作。服务器无法提取跨度上下文。

MultivaluedMap<String, String> rawHeaders = httpHeaders.getRequestHeaders();
final HashMap<String, String> headers = new HashMap<String, String>();
for (String key : rawHeaders.keySet()) {
    if(key.contentEquals("deviceKey"))
        headers.put(key, rawHeaders.get(key).get(0));
}
Tracer.SpanBuilder spanBuilder;
try {
    SpanContext parentSpanCtx = tracer.extract(Format.Builtin.HTTP_HEADERS, new TextMapExtractAdapter(headers));
    if (parentSpanCtx == null) {
        spanBuilder = tracer.buildSpan(operationName);
    }

    else {
        spanBuilder = tracer.buildSpan(operationName).asChildOf(parentSpanCtx);
    }

}
catch (IllegalArgumentException e) {
    spanBuilder = tracer.buildSpan(operationName);
}
4

1 回答 1

0
final HashMap<String, String> headers = new HashMap<String, String>();

...

if(key.contentEquals("deviceKey"))
    headers.put(key, rawHeaders.get(key).get(0));

...

tracer.extract(Format.Builtin.HTTP_HEADERS, new TextMapExtractAdapter(headers))

您似乎正在尝试基于仅包含名为deviceKey. 除非您使用自定义跟踪器,否则您确实应该将所有 HTTP 标头传递给该#extract()方法。

于 2019-03-06T06:06:35.550 回答