Windows11系统下SkyWalking环境搭建教程

news2024/11/20 12:45:38

目录

  • 前言
  • SkyWalking简介
  • SkyWalking下载
  • Agent监控实现
  • 启动配置
  • SkyWalking启动
  • Java应用程序启动
  • Elasticsearch安装
  • 总结


前言

本文为博主在项目环境搭建时记录的SkyWalking安装流程,希望对大家能够有所帮助,不足之处欢迎批评指正🤝🤝🤝


SkyWalking简介

SkyWalking是一个开源的分布式系统观测平台,它主要用于监控、追踪和诊断分布式系统中的服务和应用。SkyWalking 能帮助开发者和运维人员了解系统中的服务调用链路,分析性能瓶颈,监控各个服务的运行状态,及时发现问题。 简单的讲就是开发者可以通过SkyWalking来了解每个服务的状况、性能表现和调用关系。

SkyWalking下载

SkyWalking官网下载地址

我们在官网的Foundations下的SkyWalking APM的Distribution下载,这里博主是准备下载9.5.0版本,另外的话就是需要知道的是

  • 如果你想查看或者修改SkyWalking的源代码的话,可以点击Source下载src链接🙂
  • 当然就是只是想运行SkyWalking而不修改源代码建议和博主一样直接下载二进制文件

请添加图片描述
下载解压好的目录结构如下
请添加图片描述
从 SkyWalking 8.7.0版本开始,agent的相关代码已经从主程序包中拆分出来,成为独立的模块。这意味着,SkyWalking本身提供监控和追踪功能,但如果你需要在你的应用程序中进行性能监控或分布式追踪,就需要额外配置一个agent。这个agent会作为探针,植入到你的应用中,用于收集应用运行时的性能数据,比如响应时间、错误率、调用链路等🤔🤔🤔

我们需要下载和SkyWalking版本对应的agent版本, SkyWalking Agent不同版本的要求链接一览

请添加图片描述
因为博主下的serve是9.5.0的,所以这里的话从文档可以看出只能下载9.0.0版本的agent了
请添加图片描述
回到下载界面下载对应的Agents,这里博主还是下载可运行的二进制文件,有相应需求的话下载源代码🤝🤝
请添加图片描述
下载好之后进行解压,这里博主直接用命令行解压

tar -xvzf apache-skywalking-java-agent-9.0.0.tgz

请添加图片描述


Agent监控实现

解压好了之后我们要找到Agent Jar文件的路径
请添加图片描述
然后我们找一个java的应用程序进行配置JVM启动参数,博主的启动参数格式如下

-javaagent:/path/to/skywalking-agent.jar

博主在IDEA中给一个示例程序来配置启动参数,首先在IDEA界面右上角点击Edit Configurations
请添加图片描述
给示例程序添加JVM参数
请添加图片描述
然后我们也要配置agent.config文件的内容
请添加图片描述
主要涉及agent.namespace和collector.backend_service的配置

# The agent namespace 
agent.namespace=${SW_AGENT_NAMESPACE:}
  • 这个配置项定义了Agent 的命名空间。SW_AGENT_NAMESPACE是一个环境变量。如果没有设置这个环境变量,则默认为空(即没有指定命名空间)。
  • 命名空间的作用是当你有多个独立的SkyWalking集群时,Agent可以通过命名空间区分不同集群中的服务,防止数据混乱。如果你不需要区分多个集群,通常可以保持为空。

这里的话博主设置一个环境变量进行测试
请添加图片描述

# Backend service addresses.
collector.backend_service=${SW_AGENT_COLLECTOR_BACKEND_SERVICES:127.0.0.1:11800}
  • 这个配置项定义了SkyWalking 后端服务(OAP)的地址,Agent 会将收集到的数据发送到这个地址。
  • SW_AGENT_COLLECTOR_BACKEND_SERVICES 是一个环境变量,如果没有设置这个变量,则默认连接到 127.0.0.1:11800,这意味着后端服务在本地运行,并且监听 11800 端口。

这里博主的后端服务在本地运行就不做修改了


启动配置

在下载的SkyWalking目录中有bin文件夹,其中有启动脚本,在windows下面是bin/startup.bat
请添加图片描述
默认情况下运行启动脚本后SkyWalking UI服务会在本地运行并监听8080端口,可以通过下面的地址访问

http://localhost:8080/

但是为了避免端口冲突,我们对于UI服务的配置文件进行修改,将默认的server.port的端口号修改为8888
请添加图片描述
这里可以直接将8080修改为8888或者设置环境变量SW_SERVER_PORT两种方式都可以
请添加图片描述
另外虽然就是测试的时候博主是本地单实例运行SkyWalking,但是项目要求的环境是需要配置Nacos服务注册中心,这里博主也给出相应的修改步骤,首先是打开config文件夹下的配置文件
请添加图片描述
然后将注册中心修改为nacos,当然这里为什么要进行这一步修改呢?🤔🤔🤔对Nacos有了解需求的可以简单看看博主写的另一篇博客 Windows11系统下Nacos环境搭建教程 🫡🫡🫡

  • 希望使用Nacos来管理多个OAP实例
  • Nacos能够帮助实现负载均衡、故障检测和实例的动态拓展
    请添加图片描述

SkyWalking启动

首先的话因为Nacos是服务注册和发现的中心,所以需要最先启动
请添加图片描述
然后的话便是启动OAP服务,因为OAP后端是SkyWalking的核心服务,负责处理代理agent发送来的监控数据,OAP服务启动后会向Nacos注册自己并开始接收来自 Java 应用的监控数据🤔🤔🤔
请添加图片描述
这里博主同时启动OAP服务和UI服务时窗口闪退,无法查看到错误信息,准备来一一排查错误信息

  • 首先是检查日志文件,可惜为空🤔🤔🤔
    请添加图片描述
  • 然后检查下是否端口被占用,所设置的8888端口也没有发送冲突🤔🤔🤔
    请添加图片描述
  • 使用命令行启动,结果没有出输出错误信息,仍然闪退🤔🤔🤔
    请添加图片描述
    经调研可知,SkyWalking OAP 服务默认情况下需要一个存储引擎来存储监控数据。 博主接下来带领大家下载一下Elasticsearch(SkyWalking的默认存储引擎),跳转至下文的Elasticsearch安装目录进行Elasticsearch安装的步骤,安装完毕后将配置文件中storage部分进行配置
    请添加图片描述
    双击服务仍然不能打开,用Git Bash打开输入命令
sh startup.sh

显示已成功运行?这就很奇怪了🤨🤨🤨
请添加图片描述
然后发现生成有log文件了,一看表示我正在运行的 Java 版本过低,无法运行由更高版本的 Java 编译的类文件,崩溃了啊,新版本要求JDK11😭😭😭
请添加图片描述
安装JDK吧

JDK11 安装地址

博主直接下载压缩包来解压
请添加图片描述
解压完成后博主修改了一下JAVA_HOME的环境变量,更换为jdk11的文件夹,重启一下命令行输入java版本命令,显示jdk11表示更好成功
请添加图片描述
双击oapService.bat启动OAP服务仍然闪退,查看log文件表明Nacos时没有找到用户 ,这里是因为博主没有在SkyWalking的配置文件中修正nacos的用户名和密码配置

请添加图片描述
请添加图片描述
再次运行oapService.bat在Nacos管理页面发现服务成功注册🎉🎉🎉🎉
请添加图片描述
运行webappService.bat然后访问http://localhost:8888成功打开SkyWalking的UI界面🎉🎉🎉🎉
请添加图片描述


Java应用程序启动

启动测试程序,可以看到agent代理的相关日志信息
请添加图片描述
可以发现SkyWalking的UI界面可以看到我注册的服务的信息🎉🎉🎉
请添加图片描述


Elasticsearch安装

Elasticsearch官网下载地址

这里博主直接下载Elasticsearch在Windows下的压缩包
请添加图片描述
解压后的目录结构如下
请添加图片描述
然后配置环境变量
请添加图片描述
请添加图片描述

双击bin\elasticsearch.bat启动后会在命令行窗口看到一系列的日志输出
请添加图片描述
打开elasticsearch.yml文件进行一些配置,这里把xpack.security.enabledxpack.security.http.ssl.enabled设置为false,便于我们稍后测试Elasticsearch是否成功启动,但在生产环境中不推荐这种使用。
请添加图片描述
通过访问http:localhost:9200来验证Elasticsearch是否成功启动,如果看到类似下面的JSON响应表示已成功启动

{
    "name": "your_node_name",#节点的名称,通常是启动 Elasticsearch 时自动分配的名称或者手动配置
    "cluster_name": "your_cluster_name",#集群的名称,多个节点可以属于同一个集群也可以手动修改。
    "cluster_uuid": "your_cluster_uuid",#集群的唯一标识符
    "version": {
        "number": "your_elasticsearch_version",#Elasticsearch 的版本号
        "build_flavor": "your_build_flavor",#构建版本的风格
        "build_type": "your_build_type",#构建的安装类型
        "build_hash": "your_build_hash",#当前 Elasticsearch 版本的 Git 提交哈希值
        "build_date": "your_build_date",#构建日期,表示 Elasticsearch 这个版本的打包日期
        "build_snapshot": "your_build_snapshot",#是否是开发快照版本
        "lucene_version": "your_lucene_version",#Elasticsearch 使用的 Lucene 库的版本号
        "minimum_wire_compatibility_version": "your_minimum_wire_compatibility_version",
        "minimum_index_compatibility_version": "your_minimum_index_compatibility_version"
    },
    "tagline": "your_elasticsearch_tagline"#这是 Elasticsearch 项目的一句幽默标语
}

总结

本文记录了博主搭建SkyWalking环境从头到尾的步骤,中间会遇到一些bug,博主的解决问题的思路和处理逻辑希望能够对你有所启发,大家国庆快乐🎉🎉🎉

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

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

相关文章

openpnp - 底部相机高级校正的参数设置

文章目录 openpnp - 底部相机高级校正的参数设置概述笔记修改 “Radial Lines Per Calibration Z” 的方法不同 “Radial Lines Per Calibration Z”的校验结果不同 “Radial Lines Per Calibration Z”的设备校验动作的比较总结备注END openpnp - 底部相机高级校正的参数设置 …

5G NR物理信道简介

文章目录 NR 上行物理信道PRACHPUCCHPUSCH NR 下行物理信道PBCHPDCCHPDSCH NR 上行物理信道 PRACH PRACH(Physical Random Access Channel)物理随机接入信道,用于传导preamble 序列。PRACH 由循环前缀CP、前导序列和保护间隔三部分组成。 PUCCH PUCCH…

相互作用的检索增强 3D 分子生成扩散模型 - IRDiff 评测

IRDiff 是一个全新的基于蛋白质-配体相互作用的检索增强 3D 分子扩散模型,可以生成目标感知的分子。IRDiff 利用一组设计好的参考配体分子来引导扩散模型生成满足目标特性的分子。 一、背景介绍 IRDiff 来源于清华大学深圳国际研究生院的杨文明教授和鹏城实验室的王…

通信工程学习:什么是POP3邮局协议版本3

POP3:邮局协议版本3 POP3(Post Office Protocol - Version 3),即邮局协议版本3,是TCP/IP协议族中的一员,由RFC1939定义。它是一种用于电子邮件接收的协议,主要规定了个人计算机如何连接到互联网…

OpenCV C++ 图像处理实战 ——《基于轮廓比对的缺陷检测》

OpenCV C++ 图像处理实战 ——《基于轮廓比对的缺陷检测》 一、结果演示二、图像预处理三、基于轮廓比对的缺陷检测3.1 计算平移分量3.2 计算旋转角度3.3 缺陷检测3.4 缺陷绘制四、源码测试图像下载总结一、结果演示 二、图像预处理 本文主要是基于轮廓匹配进行缺陷识别,最主…

STM32F103C8T6的平衡小车设计(基于FreeRTOS框架)

github主页:https://github.com/snqx-lqh gitee主页:https://gitee.com/snqx-lqh 本项目github地址:https://github.com/snqx-lqh/Stm32BalanceCar 本项目gitee地址:https://gitee.com/snqx-lqh/stm32-balance-car 欢迎交流 项目介…

leetcode:380. O(1) 时间插入、删除和获取随机元素

实现RandomizedSet 类: RandomizedSet() 初始化 RandomizedSet 对象bool insert(int val) 当元素 val 不存在时,向集合中插入该项,并返回 true ;否则,返回 false 。bool remove(int val) 当元素 val 存在时&#xff0…

开发者在AIGC浪潮中的定位与策略

人工智能时代,程序员如何保持核心竞争力? 随着AIGC(如chatgpt、midjourney、claude等)大语言模型接二连三的涌现,AI辅助编程工具日益普及,程序员的工作方式正在发生深刻变革。有人担心AI可能取代部分编程工…

Python FFmpeg 安装使用教程

文章目录 什么是 FFmpeg?主要功能包括: Windows 下载安装下载解压安装配置环境变量 使用案例使用 ffmpeg-python 库转换视频格式视频剪辑添加字幕 使用 subprocess.run 执行视频格式转换 其它问题ffmpeg 不是内部或外部命令,也不是可运行的程序 个人简介…

【深度学习】反向传播-过程举例

深度学习中,一般的参数更新方式都是梯度下降法,在使用梯度下降法时,涉及到梯度反向传播的过程,那么在反向传播过程中梯度到底是怎么传递的?结合自己最近的一点理解,下面举个例子简单说明! 一、…

47.哀家要长脑子了!

1.738. 单调递增的数字 - 力扣(LeetCode) 贪心不知道怎么贪。。。每个为选择最大的,如果前一位比后一位大,就要把前一位减去1,因为要最大的嘛,一点点减,然后剩下的都变为9,因为要最大…

CSS轮廓

轮廓(outline)是绘制于元素周围的一条线,位于边框的外围(紧贴着边框),主要用来突出显示某个元素,如下图所示: 图:轮廓(outline) 轮廓和边框看起来…

【网络篇】计算机网络基础知识详述(1)(笔记)

目录 一、因特网基础认识 1. 初识因特网 2. 网络服务 3. 网络协议 4. 网络边缘 5. 物理链路 (1)双绞铜线 (2)同轴电缆 (3)光纤 6. 网络的网络(因特网) 二、网络核心 1. …

Linux Shell编程快速入门以及案例(Linux一键批量启动、停止、重启Jar包Shell脚本)

文章目录 1,shell核心概念1. 1,变量1. 2. 引号1. 3. 循环1. 4. 条件判断1. 5. 函数1. 6. 重定向1. 7. 管道1. 8. 通配符 2,案例 本文通过介绍Linux Shell编程中最重要的十个核心概念,帮助初学者快速入门。 1,shell核心…

事业单位2024最新资料大全(均已更新)

为了帮助广大考生更加高效、精准地备考,我们特别推出了2024事业单位考试最新资料大全,这份资料已全面更新,确保与最新考试大纲和趋势同步,是你备考路上的得力助手! 文章目录 一、资料亮点二、为何选择我们?…

Sqlserver 连接 chche 数据库详细步骤

zihao 第一步,安装ODBC驱动 在windows资源管理器里粘贴以下地址,会进入到驱动文件夹 ftp://ftp.intersystems.com/pub/cache/odbc/2018/ 第二步,添加ODBC 安装后,可能需要重启。然后打开控制面板,搜素ODBC&#xf…

波动方程(将麦克斯韦方程组求出只有E或H的表达式)

都在无源线性介质下求解波动方程,且复数形式的波动方程有两种解法,我们用4方法求解复数形式波动方程 电场强度E满足的波动方程: 先写出线性介质的麦克斯韦方程组 2、根据麦克斯韦方程组,获得只有E的表达式 3、再根据场的复数表示…

国外电商系统开发-需求记录

一、客户需求 1、商城后台需要添加产品、添加一级代理商; 2、一级代理商可以添加二级代理商,二级代理商需要添加店铺; 3、店铺需要购买产品(进货)、店铺也可以推广给用户(用户在用户APP里最近店铺下单、购买产品); 4、需要对接当地…

简单的微信小程序个人 个人详情页

一、示例 1.个人页面 2.个人详情页面 二、示例代码 1.wxml页面 <!--pages/user/user.wxml--> <view class"mine-wrapper"><view class"avatar-wrapper"><view><view class"avatar"><image style"borde…

沂机管理系统/data/Ajax.aspx接口存在SQL注入漏洞

漏洞描述 沂机管理系统/data/Ajax.aspx接口存在SQL注入漏洞&#xff0c;攻击者可以获取服务器权限 漏洞复现 body"后台管理系统演示版" POC GET /data/Ajax.aspx?methodlog_list&page1&limit20&fkey1&fdate12024-10-0100%3A00%3A00&fdate2…