微服务学习-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 可以实现微服务调用链路追踪。

相关推荐
蝎子莱莱爱打怪5 天前
XZLL-IM干货系列 04|Netty 长连接实战:Pipeline 怎么排、心跳怎么跳、连接怎么管
后端·微服务·面试
SamDeepThinking6 天前
Java微服务练习方式
java·后端·微服务
米丘9 天前
微前端之 Web Components 完全指南
微服务·html
通信小呆呆11 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
霸道流氓气质11 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
H__Rick11 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee11 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8611 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e11 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
小雨下雨的雨11 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙