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


声明:本文转载自https://my.oschina.net/eacdy/blog/1612218,转载目的在于传递更多信息,仅供学习交流之用。如有侵权行为,请联系我,我会及时删除。

原文:http://www.itmuch.com/spring-cloud/edgware-new-sleuth-zipkin-mq/

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

  • HTTP直连Zipkin方式

  • MQ方式,架构图如下:

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

Dalston及更低版本

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

服务器端

  1. 依赖:

    <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId> </dependency> <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-starter-sleuth</artifactId> </dependency> <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-stream-binder-rabbit</artifactId> </dependency> <dependency>   <groupId>io.zipkin.java</groupId>   <artifactId>zipkin-autoconfigure-ui</artifactId> </dependency> 
  2. 启动类上添加注解@EnableZipkinStreamServer

  3. 配置:

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

微服务端

  1. 加依赖:

    <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-sleuth-stream</artifactId> </dependency> <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-starter-sleuth</artifactId> </dependency> <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-stream-binder-rabbit</artifactId> </dependency> 
  2. 配置:

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

Edgware及更高版本

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

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

服务器端

  1. 依赖:

    <dependency>   <groupId>io.zipkin.java</groupId>   <artifactId>zipkin-autoconfigure-ui</artifactId> </dependency> <dependency>   <groupId>io.zipkin.java</groupId>   <artifactId>zipkin-server</artifactId> </dependency>  <!-- 使用消息的方式收集数据(使用rabbitmq) --> <dependency>   <groupId>io.zipkin.java</groupId>   <artifactId>zipkin-autoconfigure-collector-rabbitmq</artifactId>   <version>2.3.1</version> </dependency> 
  2. 启动类上添加@EnableZipkinServer

  3. 配置:

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

微服务端

  1. 依赖:

    <dependency>   <groupId>org.springframework.cloud</groupId>   <artifactId>spring-cloud-starter-zipkin</artifactId> </dependency> <dependency>   <groupId>org.springframework.amqp</groupId>   <artifactId>spring-rabbit</artifactId> </dependency> 
  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.xZipkin 2.x 本身已支持基于MQ的数据收集方式,故而spring-cloud-sleuth-stream 将被废弃!
  2. 两种使用方式不兼容,请读者务必注意!

本文发表于2018年01月24日 12:32
(c)注:本文转载自https://my.oschina.net/eacdy/blog/1612218,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如有侵权行为,请联系我们,我们会及时删除.

阅读 2701 讨论 0 喜欢 0

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

这世界真好,吃野东西也要留出这条命来看看

快捷链接
网站地图
提交友链
Copyright © 2016 - 2021 Cion.
All Rights Reserved.
京ICP备2021004668号-1