本片文章主要讲解skywalking的安装教程,及其在微服务架构中的链路追踪功能。
本文中的演示项目运行环境如下:
skywalking是一个开源的应用性能管理系统和可观测性分析平台。用于收集、分析、聚合和可视化来自服务和云原生基础设施的数据。SkyWalking提供了一种简单的方法来保持我们的分布式系统的清晰视图,甚至跨云。这是一个现代的APM(应用性能管理和监控技术),专门为云本地的、基于容器的分布式系统而设计。
SkyWalking在许多不同的场景中为观察和监控分布式系统提供了解决方案。首先,与传统方法一样,SkyWalking为服务提供了自动仪器代理,如Java、C#、Node.js、Go、PHP和Nginx LUA。
SkyWalking为服务、服务实例、端点和流程提供了可观察性。
SkyWalking在逻辑上分为四个部分:Probe(探针)、backend(平台后端)、storage(存储)和UI。
进入skywalking下载页面,按照以下截图进行不同版本的下载
下载成功后进行解压,解压后如下所示
重点关注以下文件夹
application.yml
、log4j.xml
、alarm-settings.yml
进入bin
文件夹,双击webappService.bat
启动skywalking服务的后端与前端。
启动成功后如下所示
既然服务启动成功,我们下一步就是通过浏览器打开skywalking的可视化界面了。
首先需要查看前端服务运行的端口,进入webapp
文件夹,查看前端配置文件application.yml
,发现前端服务的运行端口号是通过变量SW_SERVER_PORT
设置的,其默认端口号为8081
在浏览器输入localhost:8081
,进入控制台页面
本项目仅用于演示skywalking的集成过程,项目结构如下图所示
项目架构图如下所示
本项目的注册中心仅用于服务注册,其配置文件如下所示
启动注册中心后,在浏览器打开注册中心页面,输入localhost:8080/eureka
从注册中心中可以看出,我们启动的实例如下
本项目的注册中心仅用于转发请求,其配置文件如下所示
该配置中的三个路由分别用于转发请求到商品服务、订单服务和支付服务。
商品服务中定义的接口如下:
当用户调用该接口时,打印日志进行记录,然后通过feign接口调用订单服务的创建订单接口,最后返回结果,
订单服务中定义了一个由商品服务调用的接口如下:
该接口由商品服务调用,其返回值0代表成功,1代表失败。当传入的商品id为2的倍数时,则订单创建失败,否则通过feign接口调用支付服务的支付接口,最后返回结果。
支付服务中定义了一个由订单服务调用的接口如下:
该接口由订单服务调用,其返回值0代表成功,1代表失败。当传入的商品id为3的倍数时,则支付失败,否则返回成功的结果。
当我们调用商品服务的接口并传入商品id为1时
得到的结果为0,即成功。
查看日志如下:
从日志中可以看出,此次请求的调用链如下所示
当我们调用商品服务的接口并传入商品id为2时
得到的结果为1,即失败。
查看日志如下:
从日志中可以看出,此次请求的调用链如下所示
当我们调用商品服务的接口并传入商品id为3时
得到的结果为1,即失败。
查看日志如下:
从日志中可以看出,此次请求的调用链如下所示
skywalking使用java agent
将客户端植入到微服务中,当项目启动时,会自动与skywalking服务端建立连接。
下面我们进入官网下载页面
下载成功后进行解压,解压后如下所示
重点关注以下文件
skywalking要求我们通过-javaagent
将skywalking客户端集成到微服务中,现在我们对上面演示项目的各个服务进行集成
使用idea启动项目的情况下,我们进入项目的启动配置(Run/Debug Configuration)中。
以端口号为8011的商品服务为例,添加以下JVM启动参数
# skywalking客户端路径
-javaagent:E:\skywalking\skywalking-agent\skywalking-agent.jar
# 服务名称
-Dskywalking.agent.service_name=skywalking-goods
如下图所示
同样以端口号为8011的商品服务为例,当我们使用命令行启动微服务的jar包时,只需要将上面的两个参数放在-jar
参数的前面即可,如下所示
java \
-javaagent:/data/skywalking/skywalking-agent.jar \
-Dskywalking.agent.service_name=skywalking-goods \
-jar \
skywalking-goods.jar
启动参数添加完成后,重启项目,然后进入skywalking服务端的控制台页面
不难发现,我们已经把项目中的eureka服务端、网关、商品服务、订单服务、支付服务集成到skywalking了。
该页面中包含四个标签页:Service、Topology、Trace、Log
skywalking客户端提供了多种配置方式:配置文件
、jvm启动参数
、-javaagent选项
、操作系统环境变量
。
在skywalking客户端的配置文件config/agent.config
中,包含了大量客户端配置,如下截图所示。
以服务名的配置为例,配置项为agent.service_name
,对应的值将从系统环境变量中获取SW_AGENT_NAME
变量的值作为服务名,冒号:
后面为默认配置,即如果系统环境变量中不存在该配置,则取默认值
使用 skywalking. + 配置项
实现对配置文件中对应配置项的覆盖,因此优先级更高。
为什么要给配置项添加前缀skywalking.
前缀可以避免冲突。
例如:配置命名空间
-Dskywalking.agent.namespace=my_namespace
格式:
多个配置项之间以逗号","分隔
-javaagent:/path/to/skywalking-agent.jar=[option1]=[value1],[option2]=[value2]
例如配置服务名和命名空间
-javaagent:/path/to/skywalking-agent.jar=agent.service_name=my_service_name,agent.namespace=my_namespace
如果配置项或配置值中包含特殊符号,则应当使用单引号’'将其包含
-javaagent:/path/to/skywalking-agent.jar=agent.service_name=my_service_name,agent.ignore_suffix='.jpg,.jpeg'
以服务名的配置为例,配置项为agent.service_name
,对应的值将从系统环境变量中获取SW_AGENT_NAME
变量的值作为服务名,冒号:
后面为默认配置,即如果系统环境变量中不存在该配置,则取默认值。
以上就是skywalking的安装、以及如何与微服务项目进行集成的过程。
纸上得来终觉浅,绝知此事要躬行。
————————我是万万岁,我们下期再见————————