本文作者:陈刚,叩丁狼高级讲师。原创文章,转载请注明出处。
一.为什么需要服务链路追踪
我们知道微服务架构就是按照功能模块把我们的应用抽取成一个一个独立的服务,而服务和服务之间相互调用,相互影响,一个服务可能会去调用很多个其他的服务,由于服务数量众多 ,业务复杂性比较高,如果出现异常或错误,我们很难快速精确的去定位到问题服务,所以在微服务的架构中,必须实现分布式链路追踪,去追踪出每一个服务每一个请求到底有哪些服务的参与,请求路线到底是如何执行的,从而让我们服务之间的调用关系清晰可见,出现问题也能够快速进行定位。本章主要讲述在Spring Cloud Sleuth中集成Zipkin ,常见的链路追踪组件有:阿里的Eagleeye等,Twitter的Zipkin等
二. 链路追踪服务中心
链路追踪的实现和服务注册有点类似 ,我们需要创建一个链路追踪服务中心去负责追踪,和存储这些服务之间的链路数据。而我们的每个服务需要配置链路追踪服务中心地址,指向服务中心。实现链路追踪原理也很简单,
创建链路追踪服务中心
1.搭建SpringBoot应用 server-zipkin ,引入zipkin 相关依赖
pom.ml如下:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-server</artifactId>
<version>2.10.4</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.zipkin.java/zipkin-autoconfigure-ui -->
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-autoconfigure-ui</artifactId>
<version>2.10.4</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
2.在主程序启动类上打上 @EnableZipkinServer 标签,开启: 链路追踪服务功能如下:
/** * 开启:[@EnableZipkinServer](https://github.com/EnableZipkinServer "@EnableZipkinServer") 链路追踪服务 */ [@SpringBootApplication](https://github.com/SpringBootApplication "@SpringBootApplication") [@EnableZipkinServer](https://github.com/EnableZipkinServer "@EnableZipkinServer") public class ServerZipkinApplication {
public static void main(String[] args) {
SpringApplication.run(ServerZipkinApplication.class, args);
}
}
>3.配置application.properties(后面的应用可能会用properties进行配置,当然用yml进行配置也没任何问题无需在意)配置端口:
server.port=7777
#### 四.链路追踪客户端
>我们需要修改我们的服务作为链路追踪客户端,使用spring:zipkin:
base-url配置指向我们的链路追踪服务中心,这样链路追踪服务中心就可以跟踪,记录到服务之间的请求链路等信息。我这里在之前的应用基础上选用了一个消费者服务和一个生产者服务做修改,他们之间是有调用关系的。
##### 1.修改consumer,增加依赖基本依赖 : spring-cloud-starter-zipkin如下:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
##### 2.增加配置spring:zipkin:base-url:如下:
eureka:
client:
serviceUrl:
defaultZone: http://localhost:1111/eureka/ #服务地址
server:
port: 3333
spring:
application:
name: consumer1
zipkin:
base-url: http://localhost:7777
feign:
hystrix:
enabled: true
##### 3.修改producer 服务,增加 依赖和配置同上
#### 五.测试
> 分别启动 server-zipkin ,eureka-server和 producer ,consumer ,通过访问consumer 实现调用 producer ,
> 访问:[http://localhost:3333/consumer?name=xx](http://localhost:3333/consumer?name=xx) ,然后看到 “xx:你好呀这里是Producer服务”
> 再访问链路追踪服务中心监控地址:[http://localhost:7777/zipkin/](http://localhost:7777/zipkin/) 你可以看到服务调用情况:
> ![image.png](http://upload-images.jianshu.io/upload_images/807144-fcbd4ed7dab6fcd5?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
>
> 关键词解释:
> Span :基本工作单元,例如,在一个新建的span中发送一个RPC等同于发送一个回应请求给RPC,span通过一个64位ID唯一标识
> Trace:多个spans组成的一个树状结构
> 点击 Dependencies可以看到链路图如下:
> ![image.png](http://upload-images.jianshu.io/upload_images/807144-cc230b892a04d86a?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
![叩丁狼教育.jpg](https://upload-images.jianshu.io/upload_images/807144-000d1c94a7834f53.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)