链路跟踪-SkyWalking系列(二)

简介: 链路跟踪-SkyWalking系列(二)

SkyWalking平台架构组成

使用skywalk,用户可以了解服务和端点之间的拓扑关系,查看每个服务/服务实例/端点的指标,设置 告警规则。SkyWalking逻辑上分为四个部分:探针、平台后端、存储和UI。

1. SkyWalking Agent :负责从应用中,收集链路信息,发送给 SkyWalking OAP 服务器。

目前支持 SkyWalking、Zikpin、Jaeger 等提供的 Tracing 数据信息。而我们目前采用的是,SkyWalking Agent 收集 SkyWalking Tracing 数据,传递给服务器。

2. SkyWalking OAP:负责接收 Agent 发送的 Tracing 数据信息,然后进行分析(Analysis Core) ,存储到外部存储器( Storage ),最终提供查询( Query )功能。

3. Storage :Tracing 数据存储。目前支持 ES、MySQL、Sharding Sphere、TiDB、H2 多种存储器。而我们目前采用的是ES ,主要考虑是 SkyWalking 开发团队自己的生产环境采用 ES 为主。

4. SkyWalking UI :负责提供控台,查看链路等等。

SkyWalking架构图1

32bf97b8d154f736a40674bf068368e7.png

SkyWalking架构图2

3f2ffc466697bb7642681e61a08cd114.png

Agent(探针):探针收集数据并根据SkyWalking的要求对数据进行重新格式化(不同的探测器支 持不同的来源);Agent 运行在各个服务实例中,负责采集服务实例的 Trace 、Metrics 等数据,然后通过 gRPC 方式上报给 SkyWalking 后端。

OAP:SkyWalking 的后端服务,支持数据聚合、分析和流处理,包括跟踪、指标和日志。

(1)、接收 Agent 上报上来的 Trace、Metrics 等数据,交给 Analysis Core (涉及SkyWalking OAP 中的多个模块)进行流式分析,最终将分析得到的结果写入持久化存储中。

(2)、响应 SkyWalking UI 界面发送来的查询请求,将前面持久化的数据查询出来,组成正确的响应结果返回给 UI 界面进行展示。

存储:SkyWalking数据可以选择存储在已实现的ElasticSearch, H2, MySQL, TiDB, InfluxDB的持 久化系统,一般线上使用ElasticSearch 集群作为其后端存储。

UI:可视化和管理SkyWalking 数据,前后端分离,该 UI 界面负责将用户的查询操作封装为 GraphQL 请求提交给 OAP 后端触发后续的查询操作,待拿到查询结果之后会在前端负责展示。

SkyWalking 的整体架构特点

SkyWalking 的整体架构体系,总结成4大块:

探针层:SkyWalking 的核心:Agent。采用AOP模式+ 插件式架构。

数据传输层:SkyWalking 的数据传输框架:GRPC(netty+protobuffer)。

服务层,:包括数据的接收和聚合;系统预警实现。明细数据采用缓存、异步批量处理和流式写 入(队列缓冲+批量写入模式)的方式写入到存储中。

存储层:并通过 ElasticSearch 作为切入点进行剖析。

相关文章
|
监控 网络协议 Java
分布式链路追踪- SkyWalking使用手册
分布式链路追踪- SkyWalking使用手册
2577 0
分布式链路追踪- SkyWalking使用手册
|
存储 数据采集 监控
SkyWalking全景解析:从原理到实现的分布式追踪之旅
SkyWalking全景解析:从原理到实现的分布式追踪之旅
2795 1
|
关系型数据库 MySQL Java
Window环境linux环境安装skywalking
Window环境linux环境安装skywalking
566 0
|
存储 运维 监控
链路追踪Skywalking快速入门1
链路追踪Skywalking快速入门1
1213 1
|
监控 Java API
图解 Apache SkyWalking UI 的使用
Apache SkyWalking的UI界面主要分为以下几个区域: 功能选择区:这里列出了主要的UI功能,包括仪表盘、拓扑图、追踪、性能刨析、告警等功能 重新加载区:控制重新加载机制,包括定期重新加载或手动重新加载。 时间选择器:控制时区和时间范围。这里有一个中文/英文切换按钮,默认,UI使用浏览器语言设置。 下面逐一介绍功能选择区的各个功能:
2497 0
图解 Apache SkyWalking UI 的使用
|
监控 Java Shell
链路跟踪-SkyWalking系列(一)
链路跟踪-SkyWalking系列(一)
3378 2
|
9月前
|
存储 监控 Shell
SkyWalking微服务监控部署与优化全攻略
综上所述,虽然SkyWalking的初始部署流程相对复杂,但通过一步步的准备和配置,可以充分发挥其作为可观测平台的强大功能,实现对微服务架构的高效监控和治理。尽管未亲临,心已向往。将一件事做到极致,便是天分的展现。
|
消息中间件 Java 中间件
链路跟踪-SkyWalking系列(三)
链路跟踪-SkyWalking系列(三)
|
消息中间件 Java Kafka
skywalking日志收集
skywalking日志收集
skywalking日志收集
|
存储 前端开发 数据可视化
skywalking安装教程
skywalking安装教程
skywalking安装教程