【问题标题】:Enable tracing using jaeger on Java dropwizard microservices在 Java dropwizard 微服务上使用 jaeger 启用跟踪
【发布时间】:2020-09-04 17:47:28
【问题描述】:

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

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

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

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

【问题讨论】:

    标签: java kubernetes jax-rs dropwizard jaeger


    【解决方案1】:

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

            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, "/*");
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-01-11
      • 2020-06-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多