声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅。

1、概念:SpringCloudSleuth

2、具体内容

Sleuth 是一种提供的跟踪服务,也就是说利用 sleuth 技术可以实现完整的微服务的访问路径的跟踪操作。

2.1、SpringCloudSleuth 简介

微服务可以将整个的系统拆分为无数个子系统,于是这样一来就有可能出现几种可怕的场景:

· 代码的调试:

|- 你的系统有可能变慢了,于是这个时候就需要去追踪每一个微服务的执行的速度;

|- 如果现在你的微服务采用了串联的方式进行了互相调用,那么如何确认某一个微服务出现了问题呢?

· 微服务混合调用:

|- 现在微服务变为了环形调用,那么这些关系该如何描述出来?

在创建微服务的时候一定要有一些合适的开发契约,所有的开发者以及服务的调用者要按照统一的方式进行程序的调用处理, 这样才可以成为一个优秀的微服务设计。

 所以在 SpringCloud 之中提供的 Sleuth 技术就可以实现微服务的调用跟踪,也就是说它可以自动的形成一个调用连接线,通过这个连接线使得开发者可以轻松的找到所有微服务间关系,同时也可以获取微服务所耗费的时间, 这样就可以进行微服务调用状态的监控以及相应的数据分析。

Span 里面包含有如下内容:

· cs-Client Sent:客户端发出一个请求,描述的是一个 Span 开始;

· sr-Server Received:服务端接收请求,利用 sr-cs 就属于发送的网络延迟;

· ss-Server Sent:服务端发送请求(回应处理),ss-sr 就属于服务端的消耗时间;

· cr-Client Received:客户端接收到服务端数据,cr-ss 就表示回复所需要的时间。

2.2、SpringCloudSleuth 基本配置

SpringCloudSleuth 使用的核心组件在于 Twitter 推出的 zipkin 监控组件,所以本次的配置的模块一定要包含 zipkin 相关配置依赖,本次实现一个基础的调用逻辑:consumer-zuul-dept。

1、 【microcloud-sleuth-8601】通过“microcloud-provider-company-8101”项目复制得来;

2、 【microcloud-sleuth-8601】修改 pom.xml 配置文件:

· 由于 sleuth 的应用比较复杂,而且也牵扯到埋点的数据分析,本次不使用安全处理模块:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-sleuth</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.cloud</groupId>
  7. <artifactId>spring-cloud-starter-zipkin</artifactId>
  8. </dependency>
  9. <dependency>
  10. <groupId>io.zipkin.java</groupId>
  11. <artifactId>zipkin-server</artifactId>
  12. </dependency>
  13. <dependency>
  14. <groupId>io.zipkin.java</groupId>
  15. <artifactId>zipkin-autoconfigure-ui</artifactId>
  16. </dependency>

3、 【microcloud-sleuth-8601】修改 application.yml 配置文件:

  1. server:
  2. port: 8601
  3. spring:
  4. application:
  5. name: microcloud-zipkin-server

4、 【microcloud-sleuth-8601】修改程序启动类:

  1. package cn.study.microcloud;
  2.  
  3. import org.springframework.boot.SpringApplication;
  4. import org.springframework.boot.autoconfigure.SpringBootApplication;
  5. import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
  6. import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
  7.  
  8. import zipkin.server.EnableZipkinServer;
  9. @SpringBootApplication
  10. @EnableCircuitBreaker
  11. @EnableZipkinServer
  12. public class Zipkin_8601_StartSpringCloudApplication {
  13. public static void main(String[] args) {
  14. SpringApplication.run(Zipkin_8601_StartSpringCloudApplication.class, args);
  15. }
  16. }

5、 修改 hosts 配置文件,追加一个新的主机名称映射:

127.0.0.1 zipkin.com

6、 【microcloud-consumer-feign、microcloud-zuul-gateway-9501、microcloud-provider-dept-8001】修改 pom.xml 配置文件,追加 zipkin 相关依赖程序包:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-zipkin</artifactId>
  4. </dependency>

7、 【microcloud-consumer-feign、microcloud-zuul-gateway-9501、microcloud-provider-dept-8001】修改 application.yml 配置文件:

  1. spring:
  2. zipkin:
  3. base-url: http://zipkin.com:8601 # 所有的数据提交到此服务之中
  4. sleuth:
  5. sampler:
  6. percentage: 1.0 # 定义抽样比率,默认为0.1
  7. application:
  8. name: microcloud-consumer-feign

一定要有每一个微服务的名字,这样会比较好观察程序的执行轨迹。

8、 依次启动所有的服务:microcloud-sleuth-8601、microcloud-consumer-feign、microcloud-zuul-gateway-9501、microcloud-provider-dept-8001;

输入访问地址:http://zipkin.com:8601;就可以看到各个微服务之间的调用关系了

2.3、数据采集

现在已经成功的实现了一个 SpringCloudSleuth 基础操作,但是需要考虑一个实际的问题,现在所有的统计的汇总操作都是记录在内存之中的,也就是说如果你现在已经关闭了 zipkin 服务端,那么这些统计信息就将消失,很明显这样的做法并不符合实际要求,数据应该被记录下来,而且有可能你很多的微服务要发送大量的数据信息进入,为了解决这种高并发的问题,可以结合消息组件(Stream)进行缓存处理,而且本次为了方便可以将统计的结果保存在数据库之中(mysql)。

1、 需要创建数据库脚本,脚本是从官网拷贝下来的直接复制使用即可:

  1. DROP DATABASE IF EXISTS zipkin ;
  2. CREATE DATABASE zipkin CHARACTER SET UTF8 ;
  3. USE zipkin ;
  4. CREATE TABLE IF NOT EXISTS zipkin_spans (
  5. `trace_id_high` BIGINT NOT NULL DEFAULT 0 COMMENT 'If non zero, this means the trace uses 128 bit traceIds
  6. instead of 64 bit',
  7. `trace_id` BIGINT NOT NULL,
  8. `id` BIGINT NOT NULL,
  9. `name` VARCHAR(255) NOT NULL,
  10. `parent_id` BIGINT,
  11. `debug` BIT(1),
  12. `start_ts` BIGINT COMMENT 'Span.timestamp(): epoch micros used for endTs query and to implement TTL',
  13. `duration` BIGINT COMMENT 'Span.duration(): micros used for minDuration and maxDuration query'
  14. ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci;
  15. ALTER TABLE zipkin_spans ADD UNIQUE KEY(`trace_id_high`, `trace_id`, `id`);
  16. ALTER TABLE zipkin_spans ADD INDEX(`trace_id_high`, `trace_id`, `id`);
  17. ALTER TABLE zipkin_spans ADD INDEX(`trace_id_high`, `trace_id`);
  18. ALTER TABLE zipkin_spans ADD INDEX(`name`);
  19. ALTER TABLE zipkin_spans ADD INDEX(`start_ts`);
  20. CREATE TABLE IF NOT EXISTS zipkin_annotations (
  21. `trace_id_high` BIGINT NOT NULL DEFAULT 0 COMMENT 'If non zero, this means the trace uses 128 bit traceIds
  22. instead of 64 bit',
  23. `trace_id` BIGINT NOT NULL COMMENT 'coincides with zipkin_spans.trace_id',
  24. `span_id` BIGINT NOT NULL COMMENT 'coincides with zipkin_spans.id',
  25. `a_key` VARCHAR(255) NOT NULL COMMENT 'BinaryAnnotation.key or Annotation.value if type == -1',
  26. `a_value` BLOB COMMENT 'BinaryAnnotation.value(), which must be smaller than 64KB',
  27. `a_type` INT NOT NULL COMMENT 'BinaryAnnotation.type() or -1 if Annotation',
  28. `a_timestamp` BIGINT COMMENT 'Used to implement TTL; Annotation.timestamp or zipkin_spans.timestamp',
  29. `endpoint_ipv4` INT COMMENT 'Null when Binary/Annotation.endpoint is null',
  30. `endpoint_ipv6` BINARY(16) COMMENT 'Null when Binary/Annotation.endpoint is null, or no IPv6 address',
  31. `endpoint_port` SMALLINT COMMENT 'Null when Binary/Annotation.endpoint is null',
  32. `endpoint_service_name` VARCHAR(255) COMMENT 'Null when Binary/Annotation.endpoint is null'
  33. ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci;
  34. ALTER TABLE zipkin_annotations ADD UNIQUE KEY(`trace_id_high`, `trace_id`, `span_id`, `a_key`,
  35. `a_timestamp`);
  36. ALTER TABLE zipkin_annotations ADD INDEX(`trace_id_high`, `trace_id`, `span_id`) ;
  37. ALTER TABLE zipkin_annotations ADD INDEX(`trace_id_high`, `trace_id`);
  38. ALTER TABLE zipkin_annotations ADD INDEX(`endpoint_service_name`);
  39. ALTER TABLE zipkin_annotations ADD INDEX(`a_type`);
  40. ALTER TABLE zipkin_annotations ADD INDEX(`a_key`);
  41. CREATE TABLE IF NOT EXISTS zipkin_dependencies (
  42. `day` DATE NOT NULL,
  43. `parent` VARCHAR(255) NOT NULL,
  44. `child` VARCHAR(255) NOT NULL,
  45. `call_count` BIGINT
  46. ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci;
  47. ALTER TABLE zipkin_dependencies ADD UNIQUE KEY(`day`, `parent`, `child`);

2、 【microcloud-sleuth-8601】修改 pom.xml 配置文件,追加相关的依赖程序包:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.cloud</groupId>
  7. <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
  8. </dependency>
  9. <dependency>
  10. <groupId>org.springframework.boot</groupId>
  11. <artifactId>spring-boot-starter-jdbc</artifactId>
  12. </dependency>
  13. <dependency>
  14. <groupId>mysql</groupId>
  15. <artifactId>mysql-connector-java</artifactId>
  16. </dependency>
  17. <!-- <dependency>
  18. <groupId>org.springframework.cloud</groupId>
  19. <artifactId>spring-cloud-starter-sleuth</artifactId>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework.cloud</groupId>
  23. <artifactId>spring-cloud-starter-zipkin</artifactId>
  24. </dependency> -->

3、 【microcloud-sleuth-8601】修改 application.yml 配置文件:

  1. server:
  2. port: 8601
  3. spring:
  4. rabbitmq:
  5. host: rabbitmq-server
  6. port: 5672
  7. username: studyjava
  8. password: hello
  9. virtual-host: /
  10. datasource:
  11. driver-class-name: org.gjt.mm.mysql.Driver # 配置MySQL的驱动程序类
  12. url: jdbc:mysql://localhost:3306/zipkin # 数据库连接地址
  13. username: root # 数据库用户名
  14. password: mysqladmin # 数据库连接密码
  15. initialize: true
  16. application:
  17. name: microcloud-zipkin-server
  18. zipkin:
  19. storage: # 设置zipkin收集的信息通过mysql进行存储
  20. type: mysql

4、 【microcloud-sleuth-8601】可以打开安全配置项:

  1. <dependency>
  2. <groupId>cn.study</groupId>
  3. <artifactId>microcloud-security</artifactId>
  4. </dependency>

5、 【microcloud-consumer-feign、microcloud-zuul-gateway-9501、microcloud-provider-dept-8001】修改 pom.xml 配置文件:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.cloud</groupId>
  7. <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
  8. </dependency>
  9. <!-- <dependency>
  10. <groupId>org.springframework.cloud</groupId>
  11. <artifactId>spring-cloud-starter-zipkin</artifactId>
  12. </dependency> -->

6、 【microcloud-consumer-feign、microcloud-zuul-gateway-9501、microcloud-provider-dept-8001】修改 application.yml 配置文件:

  1. spring:
  2. rabbitmq:
  3. host: rabbitmq-server
  4. port: 5672
  5. username: studyjava
  6. password: hello
  7. virtual-host: /

同时删除掉已有的 zipkin.base-url 的配置项。

7、 【microcloud-sleuth-8601】修改启动程序类的使用注解:

  1. package cn.study.microcloud;
  2.  
  3. import org.springframework.boot.SpringApplication;
  4. import org.springframework.boot.autoconfigure.SpringBootApplication;
  5. import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
  6. import org.springframework.cloud.sleuth.zipkin.stream.EnableZipkinStreamServer;
  7.  
  8. import zipkin.server.EnableZipkinServer;
  9. @SpringBootApplication
  10. @EnableCircuitBreaker
  11. @EnableZipkinStreamServer
  12. public class Zipkin_8601_StartSpringCloudApplication {
  13. public static void main(String[] args) {
  14. SpringApplication.run(Zipkin_8601_StartSpringCloudApplication.class, args);
  15. }
  16. }

8、 此时依次启动各个微服务之后所有的信息都将被记录到 MySQL 数据库之中,这样即使当前的 zipkin 服务关闭了,那么也可以进行信息的持久化存储,下次启动之后依然可以读取到执行顺序。

SpringCloud系列十二:SpringCloudSleuth(SpringCloudSleuth 简介、SpringCloudSleuth 基本配置、数据采集)的更多相关文章

  1. SpringCloud系列十二:手动创建Feign

    1. 回顾 上文讲解了自定义Feign.但是在某些场景下,前文自定义Feign的方式满足不了需求,此时可使用Feign Builder API手动创建Feign. 本文围绕以下场景,为大家讲解如何手动 ...

  2. 爬虫系列(十二) selenium的基本使用

    一.selenium 简介 随着网络技术的发展,目前大部分网站都采用动态加载技术,常见的有 JavaScript 动态渲染和 Ajax 动态加载 对于爬取这些网站,一般有两种思路: 分析 Ajax 请 ...

  3. Web 前端开发精华文章推荐(jQuery、HTML5、CSS3)【系列十二】

    2012年12月12日,[<Web 前端开发人员和设计师必读文章>系列十二]和大家见面了.梦想天空博客关注 前端开发 技术,分享各种增强网站用户体验的 jQuery 插件,展示前沿的 HT ...

  4. SQL Server 2008空间数据应用系列十二:Bing Maps中呈现GeoRSS订阅的空间数据

    原文:SQL Server 2008空间数据应用系列十二:Bing Maps中呈现GeoRSS订阅的空间数据 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Se ...

  5. Alamofire源码解读系列(十二)之请求(Request)

    本篇是Alamofire中的请求抽象层的讲解 前言 在Alamofire中,围绕着Request,设计了很多额外的特性,这也恰恰表明,Request是所有请求的基础部分和发起点.这无疑给我们一个Req ...

  6. struts2官方 中文教程 系列十二:控制标签

    介绍 struts2有一些控制语句的标签,本教程中我们将讨论如何使用 if 和iterator 标签.更多的控制标签可以参见 tags reference. 到此我们新建一个struts2 web 项 ...

  7. Alamofire源码解读系列(十二)之时间轴(Timeline)

    本篇带来Alamofire中关于Timeline的一些思路 前言 Timeline翻译后的意思是时间轴,可以表示一个事件从开始到结束的时间节点.时间轴的概念能够应用在很多地方,比如说微博的主页就是一个 ...

  8. 跟我学SpringCloud | 第十二篇:Spring Cloud Gateway初探

    SpringCloud系列教程 | 第十二篇:Spring Cloud Gateway初探 Springboot: 2.1.6.RELEASE SpringCloud: Greenwich.SR1 如 ...

  9. SpringBoot系列(十二)过滤器配置详解

    SpringBoot(十二)过滤器详解 往期精彩推荐 SpringBoot系列(一)idea新建Springboot项目 SpringBoot系列(二)入门知识 springBoot系列(三)配置文件 ...

随机推荐

  1. ImCash:币安下架BSV之辩:规则、中立与去中心化

    一种看法是:一个引用价格数据和执行交易的加密货币交易所,其业务决策往往是在链外发生的,不受制于严格的.类似于准宪法的链上规则的约束,加密货币交易所可以拒绝任何人喜欢的价格和交易,而且这样做并不会损害底 ...

  2. python购物车-基础版本

    # 1. 用户先给自己的账户充钱:比如先充3000元.# 2. 页面显示 序号 + 商品名称 + 商品价格,如:# 1 电脑 1999# 2 鼠标 10# …# n 购物车结算# 3. 用户输入选择的 ...

  3. python基础day1

    一.python介绍 1.1简介 Python  (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种面向对象的解释型计算机程序设计语言,由荷兰人Guido van Rossum ...

  4. [OC] NSTimer

    注意NSTimer的销毁 NSTimer在初始化之后,加入RunLoop会导致当前界面被强引用, 所以不会执行dealloc, 需要在合适在逻辑上进行NSTimer的销毁 [_timer invali ...

  5. 简单的dfs题 --- POJ1321 棋盘问题

    题目链接: http://poj.org/problem?id=1321 题目大意: 你有k个棋子,若干个可以填的位置,要求填下一个棋子后其行和列不能填棋子. 思路: dfs策略 画图理解更好些: 填 ...

  6. linux磁盘满了的处理

    1.查看磁盘使用情况 cd  / df -h 如果 总量Size和Used一样,按就证明磁盘满了 2.查看当前文件下每个文件大小 du -sh * 一层一层去查,就可以查到占用空间最大的那个文件及产生 ...

  7. PHP序列号生成函数和字符串替换函数代码

    /** * 序列号生成器 */ function snMaker($pre = '') { $date = date('Ymd'); $rand = rand(1000000,9999999); $t ...

  8. CMD 中常见命令

    引自百度经验:https://jingyan.baidu.com/article/67508eb41d44a09cca1ce4f1.html ipConfig:查询ip ping:查询连接速度: pi ...

  9. S7 Connection 通讯

    参考两个链接: http://www.ad.siemens.com.cn/service/answer/solution.aspx?Q_ID=74626&cid=1029 https://su ...

  10. IaaS,PaaS和SaaS

    云计算的三种服务模式:IaaS,PaaS和SaaS IaaS: Infrastructure-as-a-Service(基础设施即服务)是第一层. PaaS: Platform-as-a-Servic ...