我正在尝试在我的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”没有处理程序
请帮忙!!
这似乎有点过时了,很难分辨出哪里出了问题。我的第一个猜测是采样策略,因为Jaeger采样了千分之一的痕迹,但看起来你确实设置了它。
JAEGER_SAMPLER_TYPE=常量JAEGER_SAMPLER_PARAM=1
我建议您首先使用一个简单的Configuration.fromEnv(). getTracer()
来获取您的跟踪器。然后,通过env vars控制它,可能将JAEGER_REPORTER_LOG_SPANS
设置为true
。使用此选项,您应该能够在Jaeger发出跨度时在日志中看到。
您还可以将--log-level=debug
选项设置为代理和收集器(在您的情况下为一体式),以查看这些组件何时从客户端接收跨度。