本篇内容主要讲解“怎么解决java的sleuth TraceFeignClient SpanName问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决java的sleuth TraceFeignClient SpanName问题”吧!
@Override
public Response execute(Request request, Request.Options options) throws IOException {
String spanName = getSpanName(request);
Span span = getTracer().createSpan(spanName);
if (log.isDebugEnabled()) {
log.debug("Created new Feign span " + span);
}
try {
AtomicReference<Request> feignRequest = new AtomicReference<>(request);
this.spanInjector.inject(span, feignRequest);
span.logEvent(Span.CLIENT_SEND);
addRequestTags(request);
Request modifiedRequest = feignRequest.get();
if (log.isDebugEnabled()) {
log.debug("The modified request equals " + modifiedRequest);
}
Response response = this.delegate.execute(modifiedRequest, options);
logCr();
return response;
} catch (RuntimeException | IOException e) {
logError(e);
throw e;
} finally {
closeSpan(span);
}
}
private String getSpanName(Request request) {
URI uri = URI.create(request.url());
return uriScheme(uri) + ":" + uri.getPath();
}
默认是根据uri生成spanName.如果是restful风格的话,/getuser/1 /getuser/2 就是2个span.
span一般是一个操作。比如getuser. 参数啊1. tag应该1.
如果要修改默认uri为span。
方案1:
1. 通过直接在请求上,或者在类上添加Headers的注解
@Headers({"Content-Type: application/json","Accept: application/json",Accept {contentType}})
@PostMapping(value = "/card-blank/batch-create")
Response batchCreateCard(@RequestBody CreateCardBlankDTO condition,@Param("contentType") String type);
2.重写getspan方法,从请求头获取spanName
方案二:
能够得知当前feign调用的feignclient java方法,获取方法名称为spanName
重写getspan方法,从请求头获取spanName
到此,相信大家对“怎么解决java的sleuth TraceFeignClient SpanName问题”有了更深的了解,不妨来实际操作一番吧!这里是天达云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!