在Java dropwizard微服务上使用jaeger启用跟踪



我有一个基于微服务的应用程序在Kubernetes上运行。微服务是使用dropwizard框架构建的。

我想启用跟踪,以便跟踪请求,并有一个可以帮助调试东西的解决方案。

基本上,我知道使用Spring引导的实现,它非常简单。但我想知道它在基于dropwizard的应用程序中是如何实现的?实际上,这可能吗?有人能分享一下他对这个话题的经验吗?并为我提供如何做到这一点的资源或例子?

请确保我没有使用服务网格。

我使用这两个依赖项启用了服务检测:

implementation "io.opentracing.contrib:opentracing-jaxrs2:1.0.0"
implementation "io.jaegertracing:jaeger-client:1.4.0"

而且,我使用jaeger客户端使用环境变量配置跟踪器:

JAEGER_SERVICE_NAME: yourServiceName

获取跟踪程序实例:

public static Tracer jaegerTracer() {
return Configuration.fromEnv()
.getTracer();
}

最后,在dropwizard应用程序中,您必须像一样注册跟踪器

GlobalTracer.registerIfAbsent(jaegerTracer());
jersey.register(new ServerTracingDynamicFeature());

env.servlets()
.addFilter("span-finisher", new SpanFinishingFilter())
.addMappingForUrlPatterns(EnumSet.allOf(DispatcherType.class), true, "/*");

相关内容

  • 没有找到相关文章

最新更新