当前位置: 首页 > article >正文

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


http://www.kler.cn/a/516979.html

相关文章:

  • Qt Enter和HoverEnter事件
  • pdf与ofd的区别详细对比
  • 使用 Babylon.js 开发时如何通过 CSS 实现 UI 自适应
  • 人脸识别打卡系统--基于QT(附源码)
  • 信息收集(下)
  • 【算法】经典博弈论问题——巴什博弈 python
  • CTFSHOW-WEB入门-文件包含78-81
  • Spring WebFlux 和 Spring MVC 的主要区别是什么?
  • springboot使用ssl连接elasticsearch
  • 【开源免费】基于SpringBoot+Vue.JS校园失物招领系统(JAVA毕业设计)
  • FastExcel导入Excel详细步骤
  • MyBatis-Plus之常用注解
  • Java定时任务实现方案(二)——ScheduledExecutorService
  • C#通过SDK包与三菱PLC仿真通讯
  • Java数据结构方面的面试试题以及答案解析
  • 【Go面试】基础八股文篇 (持续整合)
  • 加州大学伯克利分校最新研究:通过语言融合视听触觉异构传感器实现机器人通用操作策略微调
  • Python识别处理验证码技术详解
  • C语言程序设计十大排序—计数排序
  • 基于STM32的AI物联网计算实现指南
  • vue3+vite+ts安装wangeditor富文本编辑器
  • 【含开题报告+文档+PPT+源码】基于Java Springboot的仓库管理系统设计与实现
  • 从 Facebook 的数据泄露事件看社交平台的隐私保护责任
  • Python基于Django的花卉商城系统的设计与实现(附源码,文档说明)
  • 图形化数据报文转换映射工具
  • HTTP 配置与应用(不同网段)