基于Spring Cloud Alibaba+Skywalking的分布式链路追踪设计

embedded/2024/10/18 9:22:18/

胡弦,视频号2023年度优秀创作者,互联网大厂P8技术专家,Spring Cloud Alibaba微服务架构实战派(上下册)和RocketMQ消息中间件实战派(上下册)的作者,资深架构师,技术负责人,极客时间训练营讲师,四维口袋KVP最具价值技术专家,技术领域专家团成员,2021电子工业出版社年度优秀作者,获得2023电子工业出版技术成长领路人称号。 

1.概要设计

基于Spring Cloud AlibabaSkywalking分布式链路追踪设计,可以从以下几个方面进行归纳。

1.1 背景与目标

微服务架构中,一次外部请求往往需要经过多个模块、中间件和机器的相互调用才能完成。为了确定整个请求调用了哪些应用、模块、节点,以及它们的先后顺序和性能情况,需要引入分布式链路追踪技术。Spring Cloud AlibabaSkywalking的结合,可以为我们提供强大的分布式链路追踪能力。

1.2 技术选型与特点

(1)Spring Cloud Alibaba:提供了丰富的微服务开发所需的各类组件,包括服务发现、配置管理、熔断降级等,为构建微服务架构提供了便捷的方式。

(2)Skywalking:作为一款开源的APM(应用性能管理)工具,专为微服务、云原生架构和容器架构而设计。它提供了分布式追踪、服务网格遥测分析、度量聚合和可视化一体化解决方案。具有多种监控手段,可以通过语言探针和service mesh获得监控数据,且支持多种语言的自动探针。

1.3 设计步骤与实施

(1)环境搭建与部署:首先,需要下载并安装Skywalking,包括Skywalking AgentOAP服务器。然后,根据具体的微服务架构配置Skywalking Agent,以收集链路信息。

(2)微服务接入:在Spring Cloud Alibaba项目中,通过配置Skywalking Agent的参数,将微服务接入到Skywalking中进行追踪。这通常涉及到在服务启动脚本中添加相关参数。

(3)链路追踪与监控:一旦微服务接入完成,Skywalking就可以开始收集链路信息,并通过UI界面进行展示。开发者可以通过UI查看请求的完整调用链路、各个节点的耗时、请求状态等信息。

(4)数据持久化与告警:Skywalking还支持将追踪数据持久化到存储后端(如Elasticsearch),以便后续分析和查询。同时,它还提供了告警功能,当某些性能指标超过预设阈值时,可以触发告警通知。

1.4 优势与总结

基于Spring Cloud AlibabaSkywalking分布式链路追踪设计具有以下优势:

(1)强大的链路追踪能力:能够清晰地展示请求的完整调用链路,帮助开发者快速定位问题所在。

(2)丰富的监控手段:支持多种监控手段和语言探针,能够全面收集和分析微服务架构中的性能数据。

(3)可视化解决方案:提供了直观的UI界面,方便开发者查看和分析链路追踪数据。

(4)高度可扩展性:支持模块化设计和多种存储后端,可以根据实际需求进行灵活扩展。

2. 技术实现

基于Spring Cloud AlibabaSkywalking分布式链路追踪设计的技术实现,可以细分为以下几个步骤。

2.1 环境准备

2.1.1 安装Skywalking

(1)下载并安装SkywalkingAgentOAPObservability Analysis Platform)服务器。

2)配置OAP服务器连接的后端存储,如Elasticsearch,用于存储追踪数据。

2.1.2 配置Skywalking Agent

(1)在需要追踪的服务中配置Skywalking Agent,通常是在服务启动脚本中添加JVM参数,如-javaagent:/path/to/skywalking-agent/skywalking-agent.jar

(2)设置Skywalking OAP服务器的地址,以便Agent能够将追踪数据发送到OAP服务器。

2.2 Spring Cloud Alibaba集成

2.2.1 引入依赖

Spring Cloud Alibaba项目中,通过MavenGradle引入SkywalkingJava Agent依赖。

2.2.2 配置应用名称

application.propertiesapplication.yml中配置应用的名称,这样Skywalking UI中可以清晰地识别出各个服务。

2.2.3 启动类注解

Spring Boot的启动类上添加@EnableDiscoveryClient@EnableEurekaClient等注解(如果使用Eureka作为服务发现),以确保服务能够注册到服务注册中心,并被Skywalking正确识别。

2.3 链路追踪与数据收集

2.3.1 自动追踪

Skywalking Agent会自动拦截应用的HTTPRPC等调用,并收集链路信息,包括调用关系、耗时等。

2.3.2 自定义追踪

如果需要更细粒度的追踪,可以在代码中手动插入追踪点,使用Skywalking提供的API来记录自定义的追踪信息。

2.3.3 异步日志记录

Skywalking支持异步日志记录,以减少追踪对系统性能的影响。

2.4 数据存储与分析

2.4.1 数据存储

追踪数据被发送到OAP服务器后,会被存储到后端存储系统(如Elasticsearch)中。

2.4.2 数据分析

OAP服务器会对收集到的追踪数据进行处理和分析,生成各种性能指标和调用链信息。

2.5 可视化与告警

2.5.1 Web UI

Skywalking提供了Web UI来展示追踪数据,包括服务拓扑图、调用链详情、性能指标等。

2.5.2 告警配置

Skywalking中配置告警规则,当某些性能指标超过阈值时,可以触发告警通知,如邮件、短信等。

2.6 优化与调试

2.6.1 性能调优

根据Skywalking收集的追踪数据,分析服务的性能瓶颈,进行针对性的优化。

2.6.2 问题定位

当服务出现问题时,可以利用Skywalking的调用链追踪功能,快速定位问题所在的服务和方法。

基于Spring Cloud AlibabaSkywalking分布式链路追踪设计的技术实现,主要涉及环境准备、Spring Cloud Alibaba集成、链路追踪与数据收集、数据存储与分析以及可视化与告警等步骤。通过这些步骤,可以构建一个功能强大的分布式链路追踪系统,帮助开发团队更好地监控和优化微服务架构的性能。


http://www.ppmy.cn/embedded/6481.html

相关文章

Solidworks 2024安装教程(附免费安装包资源)

鼠标右击软件压缩包,选择“解压到Solidworks.2024”。 打开解压后的文件夹下的“SolidSQUAD”,双击“sw2024_network_serials_licensing”。 点击“是”。 点击“确定”。 复制“SolidWorks_Flexnet_Server”文件夹。 将其粘贴至C盘。 打开复制后的文件夹…

python在selenium网页模拟运行过程中需要打开文件夹上传文件的情况的解决方法

在selenium运行过程中,可能会遇到网页需要上传文件图片等情况,有时可以直接用selenium中send_keys直接上传,但是有时不行,这时我们需要用到另一个包,pywinauto 具体的代码如下, import pywinauto # pywina…

linux实用C++库之json

目录 1 介绍2 内容 1 介绍 本博客用来记录linux下json库的基本使用。 2 内容 安装: 使用: CMakeLists.txt编写:

web自动化系列-selenium方法和属性的使用(九)

继续介绍selenium中的一些方法和属性 ,下面的这些方法和前面已经介绍过的clear 、send_keys等都是在一个类中,即WebElement 。我们其实使用很多方法都是在这个类中 。 1.方法和属性 类型方法/属性说明场景属性size返回元素的大小/属性text返回元素的文…

java解决常见递归问题

最基本的,斐波那契数列,阶乘(0,1的阶乘均为1) 返回字母“x”第一次出现的位置 使用递归编写一个函数,读取一个字符串,返回字母“x”第一次出现的位置。例如,字符串 "abcdefgh…

项目实践---贪吃蛇游戏的实现

上一章,我们已经分析了贪吃蛇的具体内容,包括它是如何实现的,怎样完成这个项目的,其中就提到了 贪吃蛇有三个代码:一个是测试代码,一个是头文件代码,还有一个是主函数代码。那么今天我们就来讲一…

从OWASP API Security TOP 10谈API安全

1.前言 应用程序编程接口(API)是当今应用驱动世界创新的一个基本元素。从银行、零售、运输到物联网、 自动驾驶汽车、智慧城市,API 是现代移动、SaaS 和 web 应用程序的重要组成部分,可以在面向客 户、面向合作伙伴和内部的应用程…

单片机之从C语言基础到专家编程 - 4 C语言基础 - 4.12枚举

枚举(enumeration)是C语言的一种重要数据类型,由用户自定义一组命名的整数常量。使用枚举可以使程序具有可读性及可维护性。 1 定义枚举类型 在C语言中,使用enum关键字来定义枚举类型。下面以LED为例,介绍枚举类型的…