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

相关推荐
brave and determined11 小时前
接口通讯学习(day05):智能手机的内部高速公路:揭秘MIPI CSI与DSI技术
学习·智能手机·软件工程·制造·csi·mipi·dsi
Tonya4315 小时前
测开学习DAY37
学习
roman_日积跬步-终至千里21 小时前
【强化学习基础(2)】被动强化学习:学习价值函数
学习
逢考必过@k21 小时前
6级550学习ing
学习
小毅&Nora1 天前
【AI微服务】【Spring AI Alibaba】② Agent 深度实战:构建可记忆、可拦截、可流式的智能体系统
人工智能·微服务·spring-ai
陈天伟教授1 天前
基于学习的人工智能(7)机器学习基本框架
人工智能·学习
kong79069281 天前
微服务项目开发环境
微服务·nacos·rabbitmq·开发环境
Z***G4791 天前
网络爬虫学习:借助DeepSeek完善爬虫软件,实现模拟鼠标右键点击,将链接另存为本地文件
爬虫·学习·计算机外设
我命由我123451 天前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js