提问者:小点点

无法在jaeger用户界面中看到服务名称-JavaSpring应用程序


我正在尝试在我的javaspring应用程序中集成jaeger跟踪。我在配置文件中添加了以下代码:

@Bean public io.opentracing.Tracer jaegerTracer(){

    Sender sender = new HttpSender("http://localhost:14268/api/traces");
    com.uber.jaeger.Configuration.SenderConfiguration senderConfiguration = new com.uber.jaeger.Configuration
            .SenderConfiguration.Builder()
            .sender(sender)
            .build();

    return new com.uber.jaeger.Configuration("pilot-tracking",
            new com.uber.jaeger.Configuration.SamplerConfiguration(ProbabilisticSampler.TYPE, 1),
            new com.uber.jaeger.Configuration.ReporterConfiguration(sender)).getTracer();
}

并使用以下docker命令:

docker run-d-p 5775:5775/udp-p 6831:6831/udp-p 6832:6832/udp-p 5778:5778-p 16686:16686-p 14268:14268 jaeger追踪/多合一:最新

尽管如此,我仍然无法在jaeger ui找到我的服务

点击此网址时:http://localhost:5778/?service=pilot-tracking 输出为:收集器错误:通道错误ErrCodeBadRequest:服务“jaeger-collector”和方法“SamplingManager::getSamplingStrategy”没有处理程序

请帮忙!!


共1个答案

匿名用户

这似乎有点过时了,很难分辨出哪里出了问题。我的第一个猜测是采样策略,因为Jaeger采样了千分之一的痕迹,但看起来你确实设置了它。

JAEGER_SAMPLER_TYPE=常量JAEGER_SAMPLER_PARAM=1

我建议您首先使用一个简单的Configuration.fromEnv(). getTracer()来获取您的跟踪器。然后,通过env vars控制它,可能将JAEGER_REPORTER_LOG_SPANS设置为true。使用此选项,您应该能够在Jaeger发出跨度时在日志中看到。

您还可以将--log-level=debug选项设置为代理和收集器(在您的情况下为一体式),以查看这些组件何时从客户端接收跨度。