Spring Cloud学习笔记-012

  • 分布式服务跟踪:Spring Cloud Sleuth

  随着业务的发展,系统规模也会变得越来越大,各微服务间的调用关系也变得越来越错综复杂。通常一个由客户端发起的请求在后端系统中会经过多个不同的微服务调用来协同产生最后的请求结果,在复杂的微服务架构系统中,几乎每一个前端请求都会形成一条复杂的分布式服务调用链路,在每条链路中任何一个依赖服务出现延迟高或错误的时候都有可能引起请求最后的失败。这时候,对于每个请求,全链路调用的跟踪就变得越来越重要,通过实现对请求调用的跟踪可以帮助我们快速发现错误根源以及监控分析每条请求链路上的性能瓶颈等。

1. 准备工作,构建一些基础的设施和应用:

  ◆ 服务注册中心:demo-eureka-server,这里不做赘述,直接使用之前构建的工程即可。

  ◆ 微服务应用:demo-trace-1,实现一个REST接口/trace-1,调用该接口后将触发对trace-2应用的调用。具体如下: 

  1). 创建一个基础的sprigboot应用,命名为demo-trace-1,加入web、eureka、ribbon依赖。

  2). 创建应用主类:

  

  3).  在src\main\resources目录下创建application.yml文件:

  

  4). 创建一个基础的sprigboot应用,命名为demo-trace-2,加入web、eureka、ribbon依赖。

  5). 创建应用主类:

  

  6). 在src\main\resources目录下创建application.yml文件:

  

  7). 将demo-eureka-server、demo-trace-1和demo-trace-2三个应用都启动起来。测试trace-1接口,确认返回无误:

  

2. 完成了准备工作之后,为上面的trace-1和trace-2添加服务跟踪功能。在trace-1和trace-2的pom.xml文件中添加相关依赖:

3. 重启trace-1和trace-2,再次调用trace-1接口,观察trace-1控制台,一些日志信息,这些元素正是实现分布式服务跟踪的重要组成部分:

  • 与Zipkin整合

  Zipkin是Twitter的一个开源项目,它基于Google Dapper实现。可以使用它来收集各个服务器上请求链路的跟踪数据,并通过它提供的REST API接口来辅助查询跟踪数据以实现对分布式系统的监控程序,从而及时发现系统中出现的延迟升高问题并找出系统性能瓶颈的根源。除了面向开发的API接口之外,它还提供了方便的UI组件来帮助我们直观地搜索跟踪信息和分析请求链路明细,比如可以查询某段时间内各用户请求的处理时间等。

  Zipkin主要的4个核心组件:

  ◆ Collector:收集器组件,它主要处理从外部系统发送过来的跟踪信息,将这些信息转化为Zipkin内部处理的Span格式,以支持后续的存储、分析、展示等功能。

  ◆ Storage:存储组件,它主要处理收集器接收到的跟踪信息,默认会将这些信息存储在内存中。也可以修改此存储策略,通过使用其他存储组件将跟踪信息存储到数据库中。

  ◆ RESTful API:API组件,它主要用来提供外部访问接口。比如给客户端展示工作信息,或是外接系统访问以实现监控等。

  ◆ Web UI:UI组件,基于API组件实现的上层应用。通过UI组件,用户可以方便而又直观地查询和分析跟踪信息。

1. 创建maven工程,骨架选择quickstart,命名为demo-zipkin-server

2. 加入相关依赖:

3. 创建启动类:

4. 在src\main\resources目录下创建application.properties文件:

5. 启动该工程(注:需要JDK1.8),并访问主页面:

6. 改造之前的trace-1和trace-2工程。在两个工程中都加入相关依赖:

7. 在两个工程的配置文件中增加Zipkin Server的配置信息:

8. 重新启动两个工程,并访问trace-1接口,观察zipkin页面:

原文地址:https://www.cnblogs.com/skyer5217/p/8858119.html

时间: 2024-07-30 00:56:22

Spring Cloud学习笔记-012的相关文章

spring cloud 学习笔记--网关zuul学习

微服务是多个服务共同完成一件事情,那么"一致对外"就很有必要,就像我们去买面包,不可能先去找农民买小麦,再.... 盗图 spring cloud 引入zuul方式来实现这一功能 添加依赖 <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> </depend

Spring Cloud学习笔记 【篇一:分布式配置中心 Spring Colud Config】

一.简介 Spring Cloud Config提供了在分布式系统的外部配置的客户端支持.通过配置服务(Config Server)来为所有的环境和应用提供外部配置的集中管理.这些概念都通过Spring的Environment和PropertySource来抽象,所以它可以适用于各类Spring应用,同事支持任何语言的任何应用.它也能为你支持对应用开发环境.测试环境.生产环境的配置.切换.迁移.默认的配置实现通过git实现,同事非常容易的支持其他的扩展(比如svn等).在spring cloud

Spring Cloud学习笔记-007

声明式服务调用:Spring Cloud Feign Feign基于Netflix Feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能之外,它还提供了一种声明式的Web服务客户端定义方式. 在使用Spring Cloud Ribbon时,通常都会利用它对RestTemplate的请求拦截来实现对依赖服务的接口调用,而RestTemplate已经实现了对HTTP请求的封装处理,形成了一套模板化的调用方法.在实际开发中,由

Spring Cloud学习笔记-009

API网关服务:Spring Cloud Zuul API网关是一个更为智能的应用服务器,它的定义类似于面向对象设计模式中的Façade模式,它的存在就像是整个微服务架构系统的门面一样,所有的外部客户端访问都需要经过它来进行调度和过滤.它除了要实现请求路由.负载均衡.校验过滤等功能之外,还需要更多能力,比如与服务治理框架的结合.请求转发时的熔断机制.服务的聚合等一系列高级功能. 在Spring Cloud中提供了基于Netflix Zuul实现的API网关组件——Spring Cloud Zuu

Spring Cloud学习笔记-010

分布式配置中心:Spring Cloud Config Spring Cloud Config是Spring Cloud团队创建的一个全新的项目,用来为分布式系统中的基础设施和微服务应用提供集中化的外部配置支持,它分为服务端和客户端两个部分.其中服务端也称为分布式配置中心,它是一个独立的微服务应用,用来连接配置仓库并为客户端提供获取配置信息.加密/解密信息等访问接口:而客户端则是微服务架构中的各个微服务应用或基础设施,他们通过指定的配置中心来管理应用资源与业务相关的配置内容,并在启动的时候从配置

Spring Cloud学习笔记-004

高可用注册中心 在微服务架构这样的分布式环境中,需要充分考虑发生故障的情况,所以在生产环境中必须对各个组件进行高可用部署,对于微服务如此,对于服务注册中心也一样.如果一直使用单节点的服务注册中心,这在生产环境中显然并不合适,需要构建高可用的服务注册中心以增强系统的可用性. 在Eureka的服务治理设计中,所有节点即是服务提供方,也是服务消费方,服务注册中心也不例外.Eureka Server的高可用实际上就是将自己作为服务向其他服务注册中心注册自己,这样就可以刑场一组互相注册的服务中心,以实现服

Spring MVC 学习笔记(二):@RequestMapping用法详解

一.@RequestMapping 简介 在Spring MVC 中使用 @RequestMapping 来映射请求,也就是通过它来指定控制器可以处理哪些URL请求,相当于Servlet中在web.xml中配置 <servlet>     <servlet-name>servletName</servlet-name>     <servlet-class>ServletClass</servlet-class> </servlet>

spring cloud 学习(4) - hystrix 服务熔断处理

hystrix 是一个专用于服务熔断处理的开源项目,当依赖的服务方出现故障不可用时,hystrix有一个所谓的断路器,一但打开,就会直接拦截掉对故障服务的调用,从而防止故障进一步扩大(类似中电路中的跳闸,保护家用电器). 使用步骤:(仍然在之前的示例代码上加以改造) 一.添加hystrix依赖 compile 'org.springframework.cloud:spring-cloud-starter-hystrix' 二.在需要熔断的方法上添加注解 package com.cnblogs.y

Spring Batch学习笔记二

此系列博客皆为学习Spring Batch时的一些笔记: Spring Batch的架构 一个Batch Job是指一系列有序的Step的集合,它们作为预定义流程的一部分而被执行: Step代表一个自定义的工作单元,它是Job的主要构件块:每一个Step由三部分组成:ItemReader.ItemProcessor.ItemWriter:这三个部分将执行在每一条被处理的记录上,ItemReader读取每一条记录,然后传递给ItemProcessor处理,最后交给ItemWriter做持久化:It