安装skywalking并集成到微服务项目

news2024/12/24 9:53:56

文章目录

  • 一、前言
  • 二、介绍
    • 1. 架构
  • 三、安装skywalking服务端
  • 四、启动skywalking服务端
  • 五、微服务项目开发
    • 注册中心
    • 网关服务
    • 商品服务
    • 订单服务
    • 支付服务
    • 测试
  • 六、下载java客户端
  • 七、微服务集成skywalking客户端
    • 1. idea启动
    • 2. 命令行启动
    • 3. 集成效果
  • 八、skywalking客户端配置
    • 1. 配置文件
    • 2. jvm启动参数
    • 3. javaagent选项
    • 4. 操作系统环境变量

一、前言

本片文章主要讲解skywalking的安装教程,及其在微服务架构中的链路追踪功能。

本文中的演示项目运行环境如下:

  • springcloud:2020.0.6
  • springboot:2.5.14
  • jdk:1.8
  • skywalking:9.4.0
  • os:windows

二、介绍

skywalking是一个开源的应用性能管理系统可观测性分析平台。用于收集分析聚合可视化来自服务和云原生基础设施的数据。SkyWalking提供了一种简单的方法来保持我们的分布式系统的清晰视图,甚至跨云。这是一个现代的APM(应用性能管理和监控技术),专门为云本地的、基于容器的分布式系统而设计。

SkyWalking在许多不同的场景中为观察监控分布式系统提供了解决方案。首先,与传统方法一样,SkyWalking为服务提供了自动仪器代理,如Java、C#、Node.js、Go、PHP和Nginx LUA。

SkyWalking为服务服务实例端点流程提供了可观察性。

  • 服务:代表为传入请求提供相同行为的一组工作负载。使用仪器代理或SDK时,可以定义服务名
  • 服务实例服务组中的每个工作负载称为一个实例。像Kubernetes中的pods一样,它不需要是单个操作系统进程,但是,如果您使用的是工具代理,实例实际上是一个真正的操作系统进程
  • 端点:服务中用于传入请求的路径,例如HTTP URI路径gRPC服务类+方法签名
  • 流程:操作系统进程。在某些场景中,一个服务实例不是一个流程,比如一个pod Kubernetes可以包含多个流程。

1. 架构

SkyWalking在逻辑上分为四个部分:Probe(探针)backend(平台后端)storage(存储)UI

  • Probe(探针):探针收集遥测数据,包括各种格式的度量轨迹日志事件
  • backend(平台后端):支持数据聚合分析流式处理,包括跟踪、指标、日志和事件。充当聚合者角色、接收者角色或两者兼而有之。
  • storage(存储):通过开放/可插拔的接口存储数据。你可以选择一个现有的实现,比如ElasticSearch、H2、MySQL、TiDB、BanyanDB。
  • UI:一个高度可定制的基于web的界面,允许skywalk终端用户可视化管理skywalk数据

在这里插入图片描述

三、安装skywalking服务端

进入skywalking下载页面,按照以下截图进行不同版本的下载

在这里插入图片描述

下载成功后进行解压,解压后如下所示

在这里插入图片描述

重点关注以下文件夹

  • bin:包括用于后端服务前端UI的启动shell脚本cmd脚本
  • config:后端服务的配置文件,主要关注application.ymllog4j.xmlalarm-settings.yml
  • oap-libs:后端服务所需要的所有依赖
  • webapp:前端应用以及配置文件

四、启动skywalking服务端

进入bin文件夹,双击webappService.bat启动skywalking服务的后端与前端

在这里插入图片描述

启动成功后如下所示

在这里插入图片描述

既然服务启动成功,我们下一步就是通过浏览器打开skywalking的可视化界面了。

首先需要查看前端服务运行的端口,进入webapp文件夹,查看前端配置文件application.yml,发现前端服务的运行端口号是通过变量SW_SERVER_PORT设置的,其默认端口号为8081

在这里插入图片描述

在浏览器输入localhost:8081,进入控制台页面

在这里插入图片描述

五、微服务项目开发

本项目仅用于演示skywalking的集成过程,项目结构如下图所示

在这里插入图片描述

  • skywalking-eureka-server:eureka服务注册中心
  • skywalking-gateway:网关
  • skywalking-goods:商品服务
  • skywalking-order:订单服务
  • skywalking-payment:支付服务

项目架构图如下所示

在这里插入图片描述

注册中心

本项目的注册中心仅用于服务注册,其配置文件如下所示

在这里插入图片描述

启动注册中心后,在浏览器打开注册中心页面,输入localhost:8080/eureka

在这里插入图片描述

从注册中心中可以看出,我们启动的实例如下

  • eureka注册中心:只有一个实例,端口号为8080,为单机模式
  • 网关:只有一个实例,端口号为8090,为单机模式
  • 商品服务:两个实例,端口号分别为8011和8012,为集群模式
  • 订单服务:两个实例,端口号分别为8021和8022,为集群模式
  • 支付服务:两个实例,端口号分别为8031和8032,为集群模式

网关服务

本项目的注册中心仅用于转发请求,其配置文件如下所示

在这里插入图片描述

该配置中的三个路由分别用于转发请求到商品服务、订单服务和支付服务。

商品服务

商品服务中定义的接口如下:

在这里插入图片描述

当用户调用该接口时,打印日志进行记录,然后通过feign接口调用订单服务的创建订单接口,最后返回结果,

订单服务

订单服务中定义了一个由商品服务调用的接口如下:

在这里插入图片描述

该接口由商品服务调用,其返回值0代表成功1代表失败。当传入的商品id为2的倍数时,则订单创建失败,否则通过feign接口调用支付服务的支付接口,最后返回结果。

支付服务

支付服务中定义了一个由订单服务调用的接口如下:

在这里插入图片描述

该接口由订单服务调用,其返回值0代表成功1代表失败。当传入的商品id为3的倍数时,则支付失败,否则返回成功的结果。

测试

当我们调用商品服务的接口并传入商品id为1

在这里插入图片描述

得到的结果为0,即成功

查看日志如下:

在这里插入图片描述

从日志中可以看出,此次请求的调用链如下所示

在这里插入图片描述

当我们调用商品服务的接口并传入商品id为2

在这里插入图片描述

得到的结果为1,即失败

查看日志如下:

在这里插入图片描述

从日志中可以看出,此次请求的调用链如下所示

在这里插入图片描述

当我们调用商品服务的接口并传入商品id为3

在这里插入图片描述

得到的结果为1,即失败

查看日志如下:

在这里插入图片描述

从日志中可以看出,此次请求的调用链如下所示

在这里插入图片描述

六、下载java客户端

skywalking使用java agent将客户端植入到微服务中,当项目启动时,会自动与skywalking服务端建立连接。

下面我们进入官网下载页面

在这里插入图片描述

下载成功后进行解压,解压后如下所示

在这里插入图片描述

重点关注以下文件

  • config:客户端的配置
  • logs:日志
  • skywalking-agent.jar:skywalking的客户端

七、微服务集成skywalking客户端

skywalking要求我们通过-javaagent将skywalking客户端集成到微服务中,现在我们对上面演示项目的各个服务进行集成

1. idea启动

使用idea启动项目的情况下,我们进入项目的启动配置(Run/Debug Configuration)中

以端口号为8011的商品服务为例,添加以下JVM启动参数

# skywalking客户端路径
-javaagent:E:\skywalking\skywalking-agent\skywalking-agent.jar
# 服务名称
-Dskywalking.agent.service_name=skywalking-goods

如下图所示

在这里插入图片描述

2. 命令行启动

同样以端口号为8011的商品服务为例,当我们使用命令行启动微服务的jar包时,只需要将上面的两个参数放在-jar参数的前面即可,如下所示

java \
-javaagent:/data/skywalking/skywalking-agent.jar \
-Dskywalking.agent.service_name=skywalking-goods \
-jar \
skywalking-goods.jar

3. 集成效果

启动参数添加完成后,重启项目,然后进入skywalking服务端的控制台页面

在这里插入图片描述

不难发现,我们已经把项目中的eureka服务端网关商品服务订单服务支付服务集成到skywalking了。

该页面中包含四个标签页:ServiceTopologyTraceLog

  • Service:微服务列表。类比eureka服务端的服务列表。
  • Topology:服务拓扑图
  • Trace:服务调用链路
  • Log:服务调用日志

八、skywalking客户端配置

skywalking客户端提供了多种配置方式:配置文件jvm启动参数-javaagent选项操作系统环境变量

1. 配置文件

在skywalking客户端的配置文件config/agent.config中,包含了大量客户端配置,如下截图所示。

在这里插入图片描述

服务名的配置为例,配置项为agent.service_name,对应的值将从系统环境变量中获取SW_AGENT_NAME变量的值作为服务名,冒号:后面为默认配置,即如果系统环境变量中不存在该配置,则取默认值

2. jvm启动参数

使用 skywalking. + 配置项 实现对配置文件中对应配置项的覆盖,因此优先级更高

  • 为什么要给配置项添加前缀skywalking.

    前缀可以避免冲突

例如:配置命名空间

-Dskywalking.agent.namespace=my_namespace

3. javaagent选项

格式:

多个配置项之间以逗号","分隔

-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'

4. 操作系统环境变量

服务名的配置为例,配置项为agent.service_name,对应的值将从系统环境变量中获取SW_AGENT_NAME变量的值作为服务名,冒号:后面为默认配置,即如果系统环境变量中不存在该配置,则取默认值。

以上就是skywalking的安装、以及如何与微服务项目进行集成的过程。



纸上得来终觉浅,绝知此事要躬行。

————————我是万万岁,我们下期再见————————

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/826023.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java版本spring cloud + spring boot企业电子招投标系统源代码 tbms

功能模块: 待办消息,招标公告,中标公告,信息发布 描述: 全过程数字化采购管理,打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力&…

Nginx特性应用及载装

Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx的网站有:网易、腾讯、阿里等。 …

19.Netty源码之粘包/拆包

本节课开始我们将学习 Netty 通信过程中的编解码技术。 编解码技术这是实现网络通信的基础,让我们可以定义任何满足业务需求的应用层协议。 在网络编程中,我们经常会使用各种网络传输协议,其中 TCP 是最常用的协议。 我们首先需要了解的是 TC…

手机pdf转换成word免费版?看看这几个转换方法

手机pdf转换成word免费版?在当今信息化的时代,PDF文档已经成为公文交流、资料分享、学术论文等领域中最常用的文件格式之一。然而,PDF文档的固化特性也使其在文本编辑、内容修改等方面存在不便。因此,将PDF文档转换为Word文档已成…

离线部署 python 环境

本机 启动命令行 保存本机python安装的库 pip3 freeze > packet.txt。这样可以在当前目录下生成packet.txt。注意不要随意删除其中行,除非你清楚依赖项 获取库文件,pip3 download -r packet.txt -d ./pip_packages。从当前环境的网络中下载packet.…

springboot项目如何自动重启(使用Devtools检测修改并自动重启springboot)

1. 问题: 我们在项目开发阶段,可能经常会修改代码,修改完后就要重启Spring Boot。经常手动停止再启动,比较麻烦。 所以我们引入一个Spring Boot提供的开发工具; 只要源码或配置文件发生修改,Spring Boot应用…

突破游戏行业天花板,“技术外溢”成趋势

文 | 螳螂观察 作者 | 余一 受游戏版号发放的“放缓”、人口结构的调整,过去两年国内游戏行业过得并不算好。前不久据相关机构发布的数据显示,2022年中国游戏市场实际销售收入2658.84亿元,同比减少306.29亿元,下降10.33%。且游戏…

Maven-学习笔记

文章目录 1. Maven简介2.Maven安装和基础配置3.Maven基本使用4.Maven坐标介绍 1. Maven简介 概念 Maven是专门用于管理和构建Java项目的工具 主要功能有: 提供了一套标准化的项目结构提供了一套标准化的构建流程(编译,测试,打包,…

Vulmap和struts-scan联合使用

介绍 Vulmap 是一款 web 漏洞扫描和验证工具, 可对 webapps 进行漏洞扫描, 并且具备漏洞利用功能, 目前支持的 webapps 包括 activemq, flink, shiro, solr, struts2, tomcat, unomi, drupal, elasticsearch, fastjson, jenkins, nexus, weblogic, jboss, spring, thinkphp Vul…

尝试多数据表 sqlite

C 唯一值得骄傲的地方就是 通过指针来回寻址 😂 提高使用的灵活性 小脚本buff 加成

【基础理论】了解点过程

Maximum tsunami wave height generated by the 16 Sept. 2015 Chile earthquake, from the International Tsunami Information Center. Posted by Austin Elliott 一、说明 在这个世界上,会发生许多事件,其趋势可能遵循一种模式。在这篇博客中&#…

手把手教你制作春节微信集卡抽奖活动

春节是中国传统的重要节日,商家们纷纷希望能够通过一系列的营销活动吸引更多的用户参与。而微信集福字游戏活动成为了一个赢得春节营销的关键。在本文中,我们将介绍如何通过第三方平台/工具,如乔拓云平台,来注册并登录后台&#x…

漏洞复现--原型链污染、沙箱逃逸绕过

目录 一、原型链污染 1.prototype和__proto__区别??? 2.原型链污染是什么??? 3.哪些情况原型链会被污染??? 4.原型链污染例题 二、沙箱逃逸绕过 1.如何实现沙箱逃逸…

nsq的目录锁,源码分析

文章目录 前言 nsqd启动加锁流程及源码分析 总结 前言 前面几篇博客我们讲了nsq是什么,nsq的安装等,大家想过下面这样的问题没有,就是 问题:一个目录下能启动多个nsqd进程吗? 答案:不能 问题&#xff1…

Maven项目解决cannot resolve plugin maven-deploy-plugin:2.7

导入maven项目后,编辑的时候提示一些插件加载失败!大概率是你的网络有问题,插件下载失败。 如下图:(网络突然好了,我想截图但是没有复现,用网上找到的截图代替,明白意思就行&#x…

Docker Compose 安装与使用(常用指令)

一、简介 Docker Compose 是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建、启动和停止。使用步骤:1. 利用 Dockerfile 定义运行环境镜像 2. 使用 docker-compose.yml 家义组成应用的各服务 3. 运行 …

python制作超高难度走迷宫游戏,你要来挑战嘛~(赶紧收藏)

前言 嗨喽~大家好呀,这里是魔王呐 ❤ ~! 走迷宫,是一项充满智慧的挑战~ 作为经常刷短视频的我们,见识过不少迷宫小游戏 当然印象深刻的当然是小动物走迷宫 这里有几组挑战走迷宫的小可爱。先来看看吧! (1&#xff…

Java Maven 构建项目里面有个聚合的概念

Java 项目里面有个聚合的概念,它没有.net里面解决方案(solution)的能力,可以统一的编译项目下的所有包,或设置统一的打包路径,使用maven编译后的产物也不会像.net那样编译到当前项目的bin文件夹下面,而是统一的生成到配…

MySQL 其他数据库日志

我们了解数据库事务时,知道两种日志:重做日志,回滚日志。 对于线上数据库应用系统,突然遭遇 数据库宕机 怎么办?在这种情况下,定位宕机的原因 就非常关键。我们可以查看数据库的 错误日志。因为日志中记录…

保修管理系统

保修管理系统密切关注IT资产的保修信息,以便在发生任何故障或损坏时,供应商可以及时更换和修复任何IT硬件。自动化保修管理软件跟踪各种供应商提供的维修和服务期限的有效性,以便任何硬件都可以在保修到期之前升级,从而降低成本并…