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

skywalking链路追踪

skywalking

  • 1.简介
    • 1.1 skywalking介绍
    • 1.2 链路追踪框架对比
    • 1.3 Skywalking架构
  • 2 环境构建
    • 2.1 windows环境
      • 2.1.1 启动skywalking服务和UI界面
      • 2.1.2 在IDEA启动项目中使用Skywalking
      • 2.1.3 skywalking持久化
    • 2.2 linux环境

1.简介

微服务架构已经是一个很通用的系统架构,常见的技术栈如下图所示,这张架构图基本涵括了当前微服务体系下的各种技术栈,可能不同的技术栈有不同的开源实现。
在这里插入图片描述

1.1 skywalking介绍

● Skywalking是一个国产的开源框架,2015年有吴晟个人开源,2017年加入Apache孵化器,国人开源的产品,主要开发人员来自于华为,2019年4月17日Apache董事会批准SkyWalking成为顶级项目,支持Java、.Net、NodeJs等探针,数据存储支持Mysql、Elasticsearch等,跟Pinpoint一样采用字节码注入的方式实现代码的无侵入,探针采集数据粒度粗,但性能表现优秀,且对云原生支持,目前增长势头强劲,社区活跃。
● Skywalking是分布式系统的应用程序性能监视工具,专为微服务,云原生架构和基于容器(Docker,K8S,Mesos)架构而设计,它是一款优秀的APM(Application Performance Management)工具,包括了分布式追踪,性能指标分析和服务依赖分析等。

1.2 链路追踪框架对比

目前市面上开源的APM系统主要有CAT、Zipkin、Pinpoint、SkyWalking,大都是参考Google的Dapper实现的

功能和技术方案对比

● Zipkin是Twitter开源的调用链路分析工具,目前基于Spingcloud sleuth得到了广泛的应用,特点是轻量,部署简单。
一个韩国团队开源的产品,运用了字节码增强技术,只需要在启动时添加启动参数即可,对代码无侵入,目前支持Java和PHP语言,底层采用HBase来存储数据,探针收集的数据粒度非常细,但性能损耗大,因其出现的时间较长,完成度也很高,应用的公司较多
● Skywalking是本土开源的基于字节码注入的调用链路分析以及应用监控分析工具,特点是支持多种插件,UI功能较强,接入端无代码侵入。
● CAT是由国内美团点评开源的,基于Java语言开发,目前提供Java、C/C++、Node.js、Python、Go等语言的客户端,监控数据会全量统计,国内很多公司在用,例如美团点评、携程、拼多多等,CAT跟下边要介绍的Zipkin都需要在应用程序中埋点,对代码侵入性强。
在这里插入图片描述
在三种链路监控组件中,skywalking探针对吞吐量影响最小,zipkin对吞吐量影响适中,pinpoint的探针对吞吐量影响最大。对于内存和cpu的使用,都差不多,相差在10%之内。

1.3 Skywalking架构

SkyWalking 逻辑上分为四部分: 探针, 平台后端, 存储和用户界面。
在这里插入图片描述

● 探针 基于不同的来源可能是不一样的, 但作用都是收集数据, 将数据格式化为 SkyWalking 适用的格式.
● 平台后端, 支持数据聚合, 数据分析以及驱动数据流从探针到用户界面的流程。分析包括 Skywalking 原生追踪和性能指标以及第三方来源,包括 Istio 及 Envoy telemetry , Zipkin 追踪格式化等。 你甚至可以使用 Observability Analysis Language 对原生度量指标 和 用于扩展度量的计量系统 自定义聚合分析。
● 存储 通过开放的插件化的接口存放 SkyWalking 数据. 你可以选择一个既有的存储系统, 如 ElasticSearch, H2 或 MySQL 集群(Sharding-Sphere 管理),也可以选择自己实现一个存储系统. 当然, 我们非常欢迎你贡献新的存储系统实现。
● UI 一个基于接口高度定制化的Web系统,用户可以可视化查看和管理 SkyWalking 数据。

2 环境构建

在这里插入图片描述

● Skywalking agent和业务端绑定在一起,负责收集各种监控数据
● Skywalking oapservice是负责处理监控数据,接受agent的数据并存储在数据库中,接受来自UI的请求,查询监控数据。
● Skywalking UI提供给用户,展现各种监控数据和告警

2.1 windows环境

我们可以在Downloads | Apache SkyWalking 网址下载相对应版本的skywalking
在这里插入图片描述
在这里插入图片描述
然后解压到当前目录,目录结构如下:
在这里插入图片描述
webapp:UI前端(web监控页面)的jar包和配置文件;

oap-libs:后台应用的jar包,以及它的依赖jar包,里面的server-starter-*.jar就是启动程序;

config:启动后台应用程序的配置文件,是使用的各种配置;

bin:各种启动脚本,一般使用脚本startup.bat在Windows下启动web页面和对应的后台应用;

agent:
● skywalking-agent.jar:代理服务jar包;
● config:代理服务启动时使用的配置文件
● plugins:包含多个插件看,代理服务启动时会加载该目录下的所有插件(jar包);
● optional-plugins:可选插件,当需要支持某种功能时,比如springcloud-Gateway,则需要把对应的jar包拷贝到plugins目录下;

2.1.1 启动skywalking服务和UI界面

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
访问http://localhost:8080/查看是否成功
在这里插入图片描述

这里的8080端口时默认端口可以在webapp/webapp.yml配置文件中修改

在这里插入图片描述

2.1.2 在IDEA启动项目中使用Skywalking

在运行的程序配置jvm参数,如下图所示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

-javaagent:D:\sofaware\skywalking\apache-skywalking-apm-bin/agent/skywalking-agent.jar
-Dskywalking.agent.service_name=test
-Dskywalking.collector.backend_service=localhost:11800

需要进行链路追踪的微服务都需要在jvm配置中加入以上内容。

因为skywalking默认没有gateway的依赖,从可选插件里复制我们所需要的gateway插件到plugins中即可 (如果有可以忽略)

在这里插入图片描述
查看拓扑图以及性能追踪
在这里插入图片描述
在这里插入图片描述

2.1.3 skywalking持久化

skywalking链路追踪的内容默认存储在内存中,关闭服务之后链路信息就会丢失,那么如何持久化到MySQL数据库呢?

第一步,修改/config/application.yml文件中的以下内容
在这里插入图片描述
第二步,将MySQL的jar包放入oap-libs目录中
在这里插入图片描述
第三步,创建swtest数据库
在这里插入图片描述
第四步,重启skywalking服务
第五步,测试观察数据库内容
在这里插入图片描述
持久化数据库成功。

2.2 linux环境


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

相关文章:

  • IEC103 转 ModbusTCP 网关
  • 【docker踩坑记录】
  • 《银行保险机构数据安全管理办法》正式实施,分类分级、安全评估共筑安全防线
  • BertTokenizerFast 和 BertTokenizer 的区别
  • vue项目引入阿里云svg资源图标
  • 神经网络常见操作(卷积)输入输出
  • nginx+flask+Gunicorn反代理服务拿不到真实IP的解决
  • 数据结构|对称矩阵压缩存储的下标公式推导|如何求对称矩阵压缩存储对应的一维数组下标
  • 年假作业4
  • 记录一些git的常用操作
  • 【20240131】USB相机(查看设备列表、打开设备)
  • vscode连接ssh报错
  • C# Task的使用
  • docker部署自己的网站wordpress
  • [vscode]ssh报错: Resolver error: Error: XHR failedscode错误
  • JVM工作原理与实战(三十六):GraalVM虚拟机
  • 从小白到入门webrtc音视频通话
  • 数据库学习笔记2024/2/5
  • vue element 组件 form深层 :prop 验证失效问题解决
  • 【Flink入门修炼】1-1 为什么要学习 Flink?
  • RAG 新路径!提升开发效率、用户体验拉满
  • Linux内核与驱动面试经典“小”问题集锦(3)
  • Kubernetes实战(二十五)-快速下载k8s.gcr.io,gcr.io,quay.io镜像
  • 高宇辰:打造“π”型人才 | 提升之路系列(七)
  • strtok的使用
  • 政安晨:机器学习快速入门(二){基于Python与Pandas} {建立您的第一个机器学习模型}