随着业务发展,系统拆分导致系统调用链路愈发复杂一个前端请求可能最终需要调用很多次后端服务才能完成,当整个请求变慢或不可用时,是无法得知该请求是由某个或某些后端服务引起的,这时就需要解决如何快读定位服务故障点,以对症下药。于是就有了分布式系统调用跟踪的诞生。现今业界分布式服务跟踪的理论基础主要来自于Google 的一篇论文《Dapper, a Large-Scale Distributed Systems Tracing Infrastructure》,使用最为广泛的开源实现是 Twitter  Zipkin

Zipkin是一个开放源代码分布式的跟踪系统,它提供了在分布式环境下发送、接收、存储和可视化跟踪的机制。这使我们能够对服务之间的活动进行关联,并更清楚地了解我们服务中发生的情况。ZipkinTwitter公司开源,致力于收集服务的定时数据,以解决微服务架构中的延迟问题,包括数据的收集、存储、查找和展现。每个服务向zipkin报告计时数据,zipkin会根据调用关系通过Zipkin UI生成依赖关系图,显示了多少跟踪请求通过每个服务,该系统让开发者可通过一个 Web 前端轻松的收集和分析数据,例如用户每次请求服务的处理时间等,可方便的监测系统中存在的瓶颈。Zipkin提供了可插拔数据存储方式:In-MemoryMySqlCassandra以及Elasticsearch。接下来的测试为方便直接采用In-Memory方式进行存储,生产推荐Elasticsearch


 

今天先搭建Zipkin-server

1、        新建项目sc-zipkin-server,对应的pom.xml文件如下

 

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">


   <modelVersion>4.0.0</modelVersion>


   <groupId>spring-cloud</groupId>

   <artifactId>sc-zipkin-server</artifactId>

   <version>0.0.1-SNAPSHOT</version>

   <packaging>jar</packaging>
   <name>sc-zipkin-server</name>

   <url>http://maven.apache.org</url>


   <parent>

      <groupId>org.springframework.boot</groupId>

      <artifactId>spring-boot-starter-parent</artifactId>

      <version>2.0.4.RELEASE</version>

   </parent>



   <dependencyManagement>

      <dependencies>

        <dependency>

           <groupId>org.springframework.cloud</groupId>

           <artifactId>spring-cloud-dependencies</artifactId>

           <version>Finchley.RELEASE</version>

           <type>pom</type>

           <scope>import</scope>

        </dependency>
  </dependencies>

   </dependencyManagement>



   <properties>

      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

      <maven.compiler.source>1.8</maven.compiler.source>

      <maven.compiler.target>1.8</maven.compiler.target>

   </properties>



   <dependencies>

      <dependency>

        <groupId>org.springframework.cloud</groupId>

         <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>

      </dependency>

      <dependency>

        <groupId>io.zipkin.java</groupId>

        <artifactId>zipkin-server</artifactId>

        <version>2.11.8</version>

      </dependency>



      <dependency>

        <groupId>io.zipkin.java</groupId>

        <artifactId>zipkin-autoconfigure-ui</artifactId>

        <version>2.11.8</version>

      </dependency>


   </dependencies>

</project>

2、        新建启动文件

 

package sc.zipkin.server;



import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.cloud.netflix.eureka.EnableEurekaClient;



import zipkin2.server.internal.EnableZipkinServer;



@SpringBootApplication
@EnableEurekaClient
@EnableZipkinServer
public class ZipkinApplication {

    public static void main(String[] args) {

        SpringApplication.run(ZipkinApplication.class, args);

    }

}

备注:存在zipkin.server.EnableZipkinServerzipkin2.server.internal.EnableZipkinServer两个EnableZipkinServer注解,其中zipkin.server.EnableZipkinServer已经被标志为过期,我们这里使用zipkin2.server.internal.EnableZipkinServer

 

3、        新建配置文件application.yml

 

eureka:

  client:

    serviceUrl:

      defaultZone:http://localhost:5001/eureka/


server:

  port: 9000

spring:

  application:

    name: sc-zipkin-server

4、        分别先启动注册中心:《Spring Cloud 2.x系列之eureka注册中心单机》,再启动Zipkin-server;下图是Zipkin-server启动成功日志

 

5、        验证Zipkin是否启动成功,访问:http://127.0.0.1:9000/zipkin/

 

这篇先到这里,下篇讲解为微服务引入和配置Zipkin服务。

源码:

https://gitee.com/hjj520/spring-cloud-2.x/tree/master/sc-zipkin-server


©著作权归作者所有:来自51CTO博客作者mob604756f1e4c7的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. Spring Cloud 2.x系列之网关zuul入门(二)
  2. 如何让 iPhone 自带日历 App 显示国家法定节假日安排?
  3. 在苹果Mac上如何进行录音修剪?
  4. Jenkins+Maven+Svn实现代码自动打包与发布
  5. 苹果Mac重复文件清理工具:Duplicate File Finder Pro
  6. 数据中心
  7. Linux系统集群架构线上项目配置实战(一)
  8. 服务端测试
  9. Apache服务的反向代理及负载均衡配置

随机推荐

  1. android源码下载-等待提示动画
  2. centos下安装adb环境
  3. android:inputType参数类型说明
  4. Android通过PHP连接MySQL(传值查询)
  5. 【android】两个按钮的宽度各占屏幕的一
  6. RelativeLayout常用属性介绍
  7. Android的Selector与Shape
  8. android 各个属性
  9. Android实战技巧之二十二:Android 5.1 SDK
  10. android.webkit.WebView/WebViewClient/W