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

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...