繁体   English   中英

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

[英]Enable tracing using jaeger on Java dropwizard microservices

我有一个在 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, "/*");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM