众所周知,Spring Cloud Sleuth有两种方式整合Zipkin:

  • HTTP直连Zipkin方式

  • MQ方式,架构图如下:

    sleuth-mq-zipkin.png

Spring Cloud Edgware及更高版本中,Sleuth使用MQ方式整合Zipkin的玩法发生了巨大改变。本文将贴出新旧版本中Sleuth如何整合Zipkin的具体操作。MQ使用的是RabbitMQ(读者也可使用Kafka)。

Dalston及更低版本

如果您使用Spring Cloud Dalston或更低版本,那么整合步骤如下:

服务器端

  1. 依赖:

  org.springframework.cloud  spring-cloud-sleuth-zipkin-stream  org.springframework.cloud  spring-cloud-starter-sleuth  org.springframework.cloud  spring-cloud-stream-binder-rabbit  io.zipkin.java  zipkin-autoconfigure-ui
  1. 启动类上添加注解@EnableZipkinStreamServer 。

  2. 配置:

server:
  port: 9411
  spring:
    rabbitmq:
      host: localhost    
      port: 5672    
      username: guest    
      password: guest

微服务端

1.加依赖:

    org.springframework.cloud  spring-cloud-sleuth-stream  org.springframework.cloud  spring-cloud-starter-sleuth  org.springframework.cloud  spring-cloud-stream-binder-rabbit

2.配置:

spring:
  rabbitmq:
      host: localhost    
      port: 5672    
      username: guest    
      password: guest

Edgware及更高版本

对于Edgware,以上方式也可使用,但目前已标注为废弃 ,未来将被删除!

从Edgware开始,应如下整合Zipkin——

服务器端

1.依赖:

    io.zipkin.java    zipkin-autoconfigure-ui    io.zipkin.java    zipkin-server    io.zipkin.java    zipkin-autoconfigure-collector-rabbitmq    2.3.1


2.启动类上添加@EnableZipkinServer 。

3.配置:

server:
  port: 9411
  zipkin:
    collector:
        rabbitmq:
              addresses: localhost:5672      
              password: guest      
              username: guest      
              queue: zipkin


微服务端

1.依赖:

    org.springframework.cloud    spring-cloud-starter-zipkin    org.springframework.amqp    spring-rabbit

2.配置:

spring:
  rabbitmq:
      host: localhost    
      port: 5672    
      username: guest    
      password: guest  
  zipkin:
      rabbitmq:      
      queue: zipkin

对比及分析

对比后不难发现,从Edgware开始,Sleuth基于MQ整合Zipkin更加的简化!不过,改动还是比较大的。官方为什么要做这个改进呢?答案如下——

  1. Spring Cloud Edgware之前的版本使用Zipkin 1.x ,要想MQ方式收集数据,需整合spring-cloud-sleuth-stream 。而在Edgware及更高版本中,使用Zipkin 2.x 。Zipkin 2.x 本身已支持基于MQ的数据收集方式,故而spring-cloud-sleuth-stream 将被废弃!

  2. 两种使用方式不兼容,请读者务必注意!


原文出处:Spring Cloud Edgware新特性之九:Sleuth使用MQ方式整合Zipkin

作者:周立


赞助本站,网站的持续发展离不开你们的支持!一分也是爱ヾ(◍°∇°◍)ノ゙
登陆
      正在加载评论