为了springboot更好的集成jaeger-client,我自定义了一个starter,并且集成了dubbo链路追踪的功能,现在分享给大家,为祖国的开源事业做贡献。
为什么我要自定义jaeger-client-starter?
市场是其实有现成的jaeger-client-starter,但是并没有集成dubbo的链路追踪,满足不了的项目的需求,还需要自己开发,但是我相信这类需求还是很大的,有必要集成一下dubbo,所以自定义了简单的starter,满足基本需求没有问题。
<dependency>
<groupId>io.opentracing.contrib</groupId>
<artifactId>opentracing-spring-jaeger-web-starter</artifactId>
<version>3.3.1</version>
</dependency>
废话不多说,直接上代码:
- 自定义了@EnableTrace的注解
- 在config中实现加载JaegerTracer
- 集成dubbo的链路追踪
@EnableTrace的注解
@Target({
ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Import(JaegerClientConfig.class)
@Documented
public @interface EnableTrace {
}
JaegerClientConfig的实现
代码主要通过已agent方式来上报的,将代理的host和port设置到环境变量中,然后通过System.getenv(“JAEGER_SERVICE_NAME”)的方式获取变量
@Configuration
@ConditionalOnProperty(value = "nb.tracer", havingValue = "true", matchIfMissing = true)
@AutoConfigureBefore(io.opentracing.contrib.spring.tracer.configuration.TracerAutoConfiguration.class)
@Slf4j
public class JaegerClientConfig {
@Bean
public io.opentracing.Tracer tracer() {
//获取系统变量
log.info("load tracer env..");
String jaeger_service_name = System.getenv("JAEGER_SERVICE_NAME");
String jaeger_agent_host = System.getenv("JAEGER_AGENT_HOST");
if(jaeger_service_name != null && jaeger_agent_host != null){
Integer jaeger_agent_port = Integer.valueOf(System.getenv("JAEGER_AGENT_PORT"));
Integer jaeger_sampler_param = Integer.valueOf(System.getenv("JAEGER_SAMPLER_PARAM"));
log.info("load jaeger_service_name: {}", jaeger_service_name);
log.info("load jaeger_agent_host: {}", jaeger_agent_host);
log.info("load jaeger_agent_port: {}", jaeger_agent_port);
log.info("load jaeger_sampler_param:{}", jaeger_sampler_param);
log.info("tracer load successfully ....");
io.jaegertracing.Configuration config = new io.jaegertracing.Configuration(jaeger_service_name);
io.jaegertracing.Configuration.SenderConfiguration sender = new io.jaegertracing.Configuration.SenderConfiguration();
sender.withAgentHost(jaeger_agent_host)