springboot 项目添加jaeger调用链监控

1.添加maven依赖
<dependency>
<groupId>io.opentracing.contrib</groupId>
<artifactId>opentracing-spring-cloud-starter</artifactId>
<version>0.1.8</version>
</dependency>

<dependency>
<groupId>com.uber.jaeger</groupId>
<artifactId>jaeger-core</artifactId>
<version>0.26.0</version>
</dependency>

<dependency>
<groupId>com.uber.jaeger</groupId>
<artifactId>jaeger-b3</artifactId>
<version>0.26.0</version>
</dependency>

<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.5</version>
</dependency>
2.启动类 application添加bean

注意:http://192.168.181.99:30668/api/traces 为对应的jaeger collector地址
service-c 为服务名称

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

Reporter reporter = new RemoteReporter.Builder().withFlushInterval(10)
.withMaxQueueSize(65000)
.withSender(new HttpSender("http://192.168.181.99:30668/api/traces"))
.withMetrics(new Metrics(new NoopMetricsFactory()))
.build();

Builder builder = new Builder("service-c")
.withReporter(reporter)
.withSampler(new ConstSampler(true))
.registerInjector(Format.Builtin.HTTP_HEADERS, new B3TextMapCodec())
.registerExtractor(Format.Builtin.HTTP_HEADERS, new B3TextMapCodec());

return builder.build();

}

转载于:https://www.cnblogs.com/jiuchongxiao/p/9044444.html

当您在多个Spring Boot应用程序之间集成Jaeger时,可以按照以下步骤进行实现: 1. 添加依赖:在每个应用程序的`pom.xml`文件中添加Jaeger客户端库的依赖项。例如: ```xml <dependency> <groupId>io.jaegertracing</groupId> <artifactId>jaeger-client</artifactId> <version>1.6.0</version> </dependency> ``` 2. 配置Jaeger:在每个应用程序的配置文件(如`application.properties`或`application.yml`)中添加Jaeger的配置。确保每个应用程序具有唯一的`service-name`。例如: 应用程序1的配置: ```yaml # 应用程序1的Jaeger配置 jaeger: service-name: application1 udp-sender: host: localhost port: 6831 ``` 应用程序2的配置: ```yaml # 应用程序2的Jaeger配置 jaeger: service-name: application2 udp-sender: host: localhost port: 6831 ``` 3. 创建Jaeger Tracer Bean:在每个应用程序的配置类中创建一个Jaeger Tracer Bean。例如: 应用程序1的配置类: ```java import io.jaegertracing.Configuration; import io.jaegertracing.internal.samplers.ConstSampler; import io.opentracing.Tracer; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class JaegerConfig { @Bean public Tracer jaegerTracer() { Configuration.SamplerConfiguration samplerConfig = Configuration.SamplerConfiguration.fromEnv() .withType(ConstSampler.TYPE) .withParam(1); Configuration.ReporterConfiguration reporterConfig = Configuration.ReporterConfiguration.fromEnv() .withLogSpans(true); Configuration config = new Configuration("application1") .withSampler(samplerConfig) .withReporter(reporterConfig); return config.getTracer(); } } ``` 应用程序2的配置类: ```java import io.jaegertracing.Configuration; import io.jaegertracing.internal.samplers.ConstSampler; import io.opentracing.Tracer; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class JaegerConfig { @Bean public Tracer jaegerTracer() { Configuration.SamplerConfiguration samplerConfig = Configuration.SamplerConfiguration.fromEnv() .withType(ConstSampler.TYPE) .withParam(1); Configuration.ReporterConfiguration reporterConfig = Configuration.ReporterConfiguration.fromEnv() .withLogSpans(true); Configuration config = new Configuration("application2") .withSampler(samplerConfig) .withReporter(reporterConfig); return config.getTracer(); } } ``` 4. 使用Jaeger Tracer:在每个应用程序中使用注入的Jaeger Tracer实例进行跟踪。例如,在控制器类或服务类中: 应用程序1的控制器类: ```java import io.opentracing.Span; import io.opentracing.Tracer; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class MyController { @Autowired private Tracer tracer; @GetMapping("/app1") public String app1() { Span span = tracer.buildSpan("app1Span").start(); // 执行您的业务逻辑 span.finish(); return "Application 1"; } } ``` 应用程序2的控制器类: ```java import io.opentracing.Span; import io.opentracing.Tracer; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class MyController { @Autowired private Tracer tracer; @GetMapping("/app2") public String app2() { Span span = tracer.buildSpan("app2Span").start(); // 执行您的业务逻辑 span.finish(); return "Application 2"; } } ``` 在每个应用程序中,您可以创建不同的Span来跟踪各自的业务逻辑。这样,当应用程序之间进行调用时,每个跟踪都会被记录下来。 希望这个示例对您有所帮助!如有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值