微服务学习-SkyWalking 实时追踪服务链路

1. 全链路追踪的作用

对请求源头到底层服务的调用链路中间的所有环节进行监控。

2. SkyWalking 是什么?

官方网站:Apache SkyWalking

SkyWalkiing 是分布式系统的应用程序性能监视工具,专为微服务、云原生和基于容器(Docker、K8s、Mesos)架构而设计。

SkyWalking 是观察性分析平台和应用性能管理系统,提供分布式追踪、服务网络遥测分析、度量聚合和可视化一体化解决方案。

3. SkyWalking 整体架构

整体架构分为四个部分:

  • 上部分 Agent:负责从应用中,收集链路信息,发送给 SkyWalking OAP 服务器;
  • 下部分 SkyWalking OAP:负责接受 Agent 发送的 Tracing 数据信息,然后进行分析(Analysis Core),存储到外部存储器(Storage),最终提供查询(Query)功能;
  • 右部分 Storage:Tracing 数据存储,目前支持 ES、Mysql、Sharding Sphere、TiDB、H2多种存储器,目前采用较多的是 ES,主要考虑 SkyWalking 开发团队自己的生产环境采用 ES 为主;
  • 左部分 SkyWalking UI:负责提供控制台,查询链路等。

4. SkyWalking 环境搭建部署

4.1. 下载 SkyWalking

4.1.1. SkyWalking 的后端服务 OAP+ 可视化 UI

apache-skywalking-apm-10.0.1.tar.gz

下载地址:https://dlcdn.apache.org/skywalking/10.0.1/apache-skywalking-apm-10.0.1.tar.gz

4.1.2. 用于从微服务采集数据的探针

apache-skywalking-java-agent-9.3.0.tgz

下载地址:https://dlcdn.apache.org/skywalking/java-agent/9.3.0/apache-skywalking-java-agent-9.3.0.tgz

4.2. 搭建 SkyWalking OAP 服务

4.2.1. 修改配置
  • 先使用默认的 H2 数据库存储,不用修改 config/application.yml 配置

文件目录:apache-skywalking-apm-10.0.1\apache-skywalking-apm-bin\config

  • SkyWalking-web-ui 服务会占用 8080 端口,修改端口可以修改 webapp/application.yml

文件目录:apache-skywalking-apm-10.0.1\apache-skywalking-apm-bin\webapp

4.2.2. windows 下启动脚本 bin/startup.bat

启动成功后会启动两个服务,一个是 skywalking-oap-server,一个是 skywalking-web-ui;

skywalking-oap-server 服务启动后会暴露 11800 和 12800 两个端口,分别为收集监控数据的端口 11800 和接受前端请求的端口 12800。

4.2.3. 访问UI界面

端口修改为 18080,访问:http://localhost:18080

5. 微服务接入 SkyWalking Agent 探针

5.1. 微服务配置 jvm 参数,接入 skywalking

以订单服务为例,idea 启动配置中配置 skywalking agent

复制代码
-javaagent:D:\icoolkj\apache-skywalking-java-agent-9.3.0\skywalking-agent\skywalking-agent.jar
-DSW_AGENT_NAME=icoolkj-mall-order
-DSW_AGENT_COLLECTOR_BACKEND_SERVICES=icoolkj-mall-skywalking-server:11800

商品、库存、账户服务都同上增加配置参数。

5.2. 重新启动服务,测试

用户下单,在 SkyWalking UI 界面查看是否有链路数据

注意:没有查看到网关服务的数据问题

  • 通过 maven 查询当前网关使用的依赖版本;
  • 需要找到对应的网关版本,这里找到 4.x 版本,具体路径:

D:\icoolkj\apache-skywalking-java-agent-9.3.0\skywalking-agent\optional-plugins\apm-spring-cloud-gateway-4.x-plugin-9.3.0.jar

  • 将该版本拷贝到 D:\icoolkj\apache-skywalking-java-agent-9.3.0\skywalking-agent\plugins 下
  • 界面查看链路数据

6. 小结

通过 Skywalking 可以实现微服务调用链路追踪。

相关推荐
雨辰AI2 小时前
SpringBoot3 + 人大金仓 V9 微服务监控实战|Prometheus+Grafana+SkyWalking 全链路监控
数据库·后端·微服务·grafana·prometheus·skywalking
幸福巡礼3 小时前
【LangChain 1.2 实战(一)】 概述
笔记·学习·langchain
知识分享小能手3 小时前
R语言入门学习教程,从入门到精通,R语言数据计算与分组统计(9)
开发语言·学习·r语言
lizhihai_994 小时前
股市学习心得—半导体12种核心材料
大数据·人工智能·学习
sakiko_4 小时前
UIKit学习笔记3-布局、滚动视图、隐藏或显示视图
前端·笔记·学习·objective-c·swift·uikit
中冕—霍格沃兹软件开发测试5 小时前
区块链交易最终一致性测试的核心挑战与实践框架
微服务·架构·单元测试·区块链·集成测试·旅游
嵌入式-老费5 小时前
瑞芯微soc的学习和应用(题外话之esp32开发)
学习
辰同学ovo6 小时前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
ting94520006 小时前
告别无效学习:Scholé 如何用 AI 重构职场学习,让学习直接嵌入工作流
人工智能·学习·重构
xian_wwq6 小时前
【学习笔记】Harness到底是什么
笔记·学习·ai·harness