ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

微服务架构学习-进阶篇--14,分布式跟踪:Zipkin演练

2019-03-22 18:47:57  阅读:303  来源: 互联网

标签:sleuth 14 zipkin spring Zipkin boot springframework server 进阶篇


第一节,为什么要用zipkin,它解决了什么问题?

在这里插入图片描述

第二节,编写搭建zipkin server

(1)在sleuth模块下新建maven项目,命名为sleuth-zipkin-server。
(2)修改pom文件。

<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
    <groupId>com.twf.springboot</groupId>
	<artifactId>sleuth-zipkin-server</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>sleuth-zipkin-server</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.4.7.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>
	</properties>

	<dependencies>
		<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>
		
		<dependency>
	      <groupId>io.zipkin.java</groupId>
	      <artifactId>zipkin-autoconfigure-ui</artifactId>
	    </dependency>
	    <dependency>
	      <groupId>io.zipkin.java</groupId>
	      <artifactId>zipkin-server</artifactId>
	    </dependency>
	    
	</dependencies>
	
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Dalston.SR1</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>
</project>

(3)修改配置文件

spring.application.name=zipkinServer
server.port=9411

(4)添加一个启动类

package com.twf.sleuth.zipkin.server;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import zipkin.server.EnableZipkinServer;

@SpringBootApplication
@EnableZipkinServer // 开启Zipkin服务端
public class ZipkinApplication {

	public static void main(String[] args) {
		SpringApplication.run(ZipkinApplication.class, args);
	}
}

(5)启动eureka注册中心,然后启动该项目。
(6)浏览器访问http://localhost:9411,界面如下:
在这里插入图片描述

第三节,编写springcloud与zipkin的例子

(1)拷贝sleuth-elk-consumer和sleuth-elk-product,重命名为sleuth-zipkin-consumer和sleuth-zipkin-product。
(2)修改sleuth-zipkin-consumer和sleuth-zipkin-product-core的pom文件–修改引入的api依赖为sleuth-zipkin-product-api,然后去掉logstash的依赖,添加zipkin的依赖。

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-sleuth-zipkin</artifactId>
</dependency>

(3)然后在sleuth-zipkin-consumer和sleuth-zipkin-product-core的配置文件中添加如下配置:

spring.zipkin.base-url=http://127.0.0.1:9411

(4)启动zipkin的服务端,再启动这两个项目。
(5)浏览器访问http://localhost:8114/productList,获取到数据,然后浏览器访问http://localhost:9411/,界面如下:
在这里插入图片描述
点击Dependencies,依赖的界面如下:
在这里插入图片描述
点击e-book-consumer-order,界面如下:
在这里插入图片描述

第四节,zipkin的底层原理剖析

在上一节的基础上,点击“Find Traces”
在这里插入图片描述
然后出现如下界面:
在这里插入图片描述
此时我们可以看到右上角有一个“JSON”的字样,点击可以查看json格式的完整跟踪信息,如果能够看懂这些json数据,就可以明白zipkin的原理了(这是老师说的~~)。
然后点击红框部分,出现如下部分:
在这里插入图片描述
在点击红框部分,可以看到列表形式的跟踪数据:
在这里插入图片描述
点击右上角的json,可以出现json格式的跟踪信息,
下面是一份模板数据的解释说明:
在这里插入图片描述
上面的事件类型有如下四种:
cs:Client Start,表示客户端发起请求 ;一个span的开始;
cr:Client Received,表示客户端获取到服务端返回信息;一个span的结束
sr:Server Receive,表示服务端收到请求
ss:Server Send,表示服务端完成处理,并将结果发送给客户端

它们之间的计算代表如下意思:
sr-cs:网络延迟
ss-sr:逻辑处理时间
cr-cs:整个流程时间

第五节,采用rabbitmq收集跟踪数据

待补。

第六节跟踪数据落地mysql

待补。

标签:sleuth,14,zipkin,spring,Zipkin,boot,springframework,server,进阶篇
来源: https://blog.csdn.net/tanwenfang/article/details/88747081

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有