skywalking学习

文章目录


前言

本文主要介绍最近时间学习skywalking的一些内容


一、skywalking单体安装部署

1. 下载skywalking

下载地址

下载对应的版本,上传到虚拟机

2. 部署oap和oap-ui服务

解压对应的下载的包

shell 复制代码
tar -zxvf apache-skywalking-apm-9.7.0.tar.gz

.sh是linux上的执行文件

.bat是windows上的脚本文件

在linux上我们可以通过 sh startup.sh来启动skywalking,但是它会存在一些问题 ,这个脚本

因此我们可以分开启动 oap服务和webui页面

最好用两个命令行窗口来启动

shell 复制代码
sh oapService.sh  # 启动oap
sh webappService.sh  # 启动 web ui

这样默认启动数据会存储在h2 内存数据库中,关闭程序后数据不保留

我们可以修改对应的配置文件,存储到其它数据库中,es,mysql等

3. 测试skywalking监控springboot应用

下载java-agent并解压

启动好skywalking服务后,就可以用应用程序进行连接,这里使用idea进行连接

添加参数

复制代码
-javaagent:探针jar所在位置
-DSWAGENTNAME=skywalking-demo
-DSWAGENTCOLLECTORBACKENDSERVICES=192.168.184.200:11800   # 部署oap服务的地址

再点击运行即可自动连接到skywalking

二、搭建swck(skywalking集群)

1.安装k8s

本文主要参考
centos7 部署k8s 1.28.2
K8s集群搭建教程

根据上面的过程部署好k8s平台

注意 k8s版本不一样 部署的要求不一样

如:k8s 1.24以后版本需要装cri-docker等工具

docker安装需要配置阿里云容器镜像加速服务

2.下载swck

swck github地址

并进行安装

参考这个文档skywalking 官网 swck教程

3.设置pod自动注入java agent

直接加一个参数即可swck-injection=enabled

三、skywalking监控python

python agent支持uWSGI 和Gunicorn

使用 SkyWalking Python 代理命令行界面 (sw-python CLI)

也可以通过之前的sdk的方式集成skywalking

  1. 使用pip 安装 skywalking的agent

    pip install "apache-skywalking"

  2. 设置环境变量
    设置oap服务的地址
    export SW_AGENT_COLLECTOR_BACKEND_SERVICES=localhost:11800

  3. 运行项目即可
    原来的运行命令
    下面运行需要去掉注释,放到同一行

shell 复制代码
uwsgi --die-on-term
    --http 0.0.0.0:5000  # 应用程序的ip地址
    --http-manage-expect 
    --master --workers 3 
    --enable-threads 
    --threads 3 
    --manage-script-name 
    --mount /=main:app  # main.py 下的 app 模块

集成skywalking的命令

shell 复制代码
sw-python run -p   # 多添加这一行即可
uwsgi --die-on-term
    --http 0.0.0.0:5000 
    --http-manage-expect 
    --master --workers 3 
    --enable-threads 
    --threads 3 
    --manage-script-name 
    --mount /=main:app

四、skywalking监控cpp

skywalking监控cpp程序,目前只有通过sdk的方式进行集成
官网集成c++的sdk

github上有详细的介绍,但是这个下载过程可能会遇到无法下载子包的问题

可以按照详细的步骤进行编译,再引入到我们的项目中

但是我编译出现了很多问题,一直没有成功,对c++这一块不熟!!!


总结

通过学习了解了skywalking的使用,如何集成java,python等应用,k8s平台的安装部署等。

参考

b站 叩丁狼--skywalking安装教程 讲的很详细,思维导图也全,监控java
skywalking官网教程
官网python agent教程
官网集成c++的sdk cpp想要集成skywalking当前没有自动的agent,需要通过sdk的内嵌代码方式进行集成
swck github地址
skywalking 官网 swck教程
centos7 部署k8s 1.28.2
K8s集群搭建教程

相关推荐
兵慌码乱5 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
小bo波7 小时前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
luckdewei8 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi0014 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn15 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
nanxun8861 天前
记一次诡异的 Docker 容器"串包"故障排查
java
金銀銅鐵1 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
用户1563068103511 天前
Day01 | Java 基础(Java SE)
java
行者全栈架构师1 天前
Maven dependency:tree 的 8 个高级用法
java·后端