如何解决在Java dropwizard微服务上使用jaeger启用跟踪
我有一个在Kubernetes上运行的基于微服务的应用程序。 这些微服务是使用dropwizard框架构建的。
我想启用跟踪功能以跟踪请求,并提供可以帮助调试内容的解决方案。
基本上,我知道使用Spring Boot的实现非常简单。 但我想知道在基于dropwizard的应用程序中怎么可能? 实际上,这可能吗? 有人可以分享他在该主题上的经验吗? 并向我提供资源或如何做到这一点的示例?
请确保我没有使用服务网格。
解决方法
我使用这两个依赖项对服务启用了检测:
implementation "io.opentracing.contrib:opentracing-jaxrs2:1.0.0"
implementation "io.jaegertracing:jaeger-client:1.4.0"
而且,我使用jaeger-client使用环境变量来配置跟踪器:
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,"/*");
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。