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

SkyWalking持久化追踪数据

skywalking-oap-server服务启动时,默认使用 H2数据库存储(不会持久化,重启skyWalking之前的数据会丢失 )。如果我们想使用其他持久化存储,比如:MySQL、Elasticearch等数据库,可以在 config/applicaiton.yml来修改数据的存储等

一、使用MySQL持久化存储

1、修改数据的存储

在 config/applicaiton.yml中,设置使用 MySQL作为持久化存储的仓库,并修改 MySQL的连接信息。

1.1 设置MySQL存储并修改 MySQL的连接信息

storage:
  # selector: ${SW_STORAGE:h2}
	# 选择使用mysql。默认使用 h2(不会持久化)。
  selector: ${SW_STORAGE:mysql}
  mysql:
    properties:
			# 数据库连接信息,sw_test数据库(自定义) 
      jdbcUrl: ${SW_JDBC_URL:"jdbc:mysql://localhost:3306/sw_test?rewriteBatchedStatements=true&serverTimezone=GMT"}
    	# 用户名
      dataSource.user: ${SW_DATA_SOURCE_USER:root}
    	# 密码
      dataSource.password: ${SW_DATA_SOURCE_PASSWORD:xxxxx}
      dataSource.cachePrepStmts: ${SW_DATA_SOURCE_CACHE_PREP_STMTS:true}
      dataSource.prepStmtCacheSize: ${SW_DATA_SOURCE_PREP_STMT_CACHE_SQL_SIZE:250}
      dataSource.prepStmtCacheSqlLimit: ${SW_DATA_SOURCE_PREP_STMT_CACHE_SQL_LIMIT:2048}
      dataSource.useServerPrepStmts: ${SW_DATA_SOURCE_USE_SERVER_PREP_STMTS:true}
    metadataQueryMaxSize: ${SW_STORAGE_MYSQL_QUERY_MAX_SIZE:5000}
    maxSizeOfBatchSql: ${SW_STORAGE_MAX_SIZE_OF_BATCH_SQL:2000}
    asyncBatchPersistentPoolSize: ${SW_STORAGE_ASYNC_BATCH_PERSISTENT_POOL_SIZE:4}

1.2 添加 MySQL数据驱动包

将 MySQL数据驱动包放到到 oap-libs目录中。

在这里插入图片描述

2、启动SkyWalking APM服务

配置好之后,需要在 MySQL中创建指定的 sw_test数据库(必须先创建,否则启动时会找不到数据库)。

然后启动 SkyWalking APM服务。可以在 sw_test数据库中自动生成了很多表,说明启动成功了。

在这里插入图片描述

3、测试追踪数据持久化

访问 Skywalking UI界面。然后重启应用项目,随机访问几个接口。

在这里插入图片描述
测试追踪数据会不会丢失?

重启 SkyWalking APM服务,发现验证追踪数据还在。

在这里插入图片描述

二、使用 Elasticsearch持久化存储

与使用 MySQL操作类似。

1、修改数据的存储

在 config/applicaiton.yml中,设置使用 Elasticsearch作为持久化存储的仓库,并修改 Elasticsearch的连接信息。

1.1 设置 Elasticsearch存储并修改 Elasticsearch的连接信息

这里展示需要修改的信息,其他参数选择默认。

storage:
  # 选择使用elasticsearch。
  # selector: ${SW_STORAGE:mysql}
  selector: ${SW_STORAGE:elasticsearch}
  elasticsearch:
  	# 指定命名空间(自定义,索引命名必须小写),用于生成索引的前缀。方便管理索引。
    namespace: ${SW_NAMESPACE:"sw_es_"}
	# ES连接信息
    clusterNodes: ${SW_STORAGE_ES_CLUSTER_NODES:192.168.xxx.xxx:9200}
    protocol: ${SW_STORAGE_ES_HTTP_PROTOCOL:"http"}
    connectTimeout: ${SW_STORAGE_ES_CONNECT_TIMEOUT:3000}
    socketTimeout: ${SW_STORAGE_ES_SOCKET_TIMEOUT:30000}
    responseTimeout: ${SW_STORAGE_ES_RESPONSE_TIMEOUT:15000}
    numHttpClientThread: ${SW_STORAGE_ES_NUM_HTTP_CLIENT_THREAD:0}
	# 用户名和密码
    user: ${SW_ES_USER:""}
    password: ${SW_ES_PASSWORD:""}    

2、启动 Elasticsearch服务

在这里插入图片描述

3、启动SkyWalking APM服务

启动 SkyWalking APM服务。会向 Elasticsearch中创建大量的 index索引,说明启动成功了。

注意:我们发现索引命名的前缀最后会自动拼接_。所以我们在指定前缀时,最后面不要写_。

在这里插入图片描述

4、测试追踪数据持久化

访问 Skywalking UI界面。然后重启应用项目,随机访问几个接口。

在这里插入图片描述

测试追踪数据会不会丢失?

重启 SkyWalking APM服务,发现验证追踪数据还在。

在这里插入图片描述

– 求知若饥,虚心若愚。

相关文章:

  • 数据导入与预处理-第4章-pandas数据获取
  • 机器学习之线性规划原理详解、公式推导(手推)、以及简单实例
  • 计算机网络——OSI 参考模型
  • 【.Net实用方法总结】 整理并总结System.IO中StreamWriter类及其方法介绍
  • openGl坐标系统
  • 实用工具系列 - Pycharm安装下载使用
  • Pyecharts绘图笔记
  • SNARK性能及安全
  • 学会 Python 自动安装第三方库,从此跟pip说拜拜
  • 3.前端开发就业前景
  • Discovery服务发现与Eureka自我保护机制及总结步骤
  • 机器学习01
  • 类加载器及反射简单笔记
  • MT6701磁编码器使用指南,14Bit单圈绝对值,I2C stm32 HAL库读角度
  • leetcode竞赛:20220918周赛
  • echarts的各种常用效果展示
  • JavaScript的使用你知道几种?(上)
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • JS进阶 - JS 、JS-Web-API与DOM、BOM
  • Linux各目录及每个目录的详细介绍
  • PHP面试之三:MySQL数据库
  • Redash本地开发环境搭建
  • vue-cli3搭建项目
  • web标准化(下)
  • 闭包,sync使用细节
  • 初识 webpack
  • 高性能JavaScript阅读简记(三)
  • 基于OpenResty的Lua Web框架lor0.0.2预览版发布
  • 解析带emoji和链接的聊天系统消息
  • 聚类分析——Kmeans
  • 如何用vue打造一个移动端音乐播放器
  • 算法之不定期更新(一)(2018-04-12)
  • 物联网链路协议
  • 项目管理碎碎念系列之一:干系人管理
  • 学习笔记TF060:图像语音结合,看图说话
  • (4)(4.6) Triducer
  • (9)STL算法之逆转旋转
  • (k8s)Kubernetes本地存储接入
  • (zz)子曾经曰过:先有司,赦小过,举贤才
  • (附源码)ssm捐赠救助系统 毕业设计 060945
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • (四)汇编语言——简单程序
  • (转)C#开发微信门户及应用(1)--开始使用微信接口
  • .NET 4 并行(多核)“.NET研究”编程系列之二 从Task开始
  • .NET Core 控制台程序读 appsettings.json 、注依赖、配日志、设 IOptions
  • .net 生成二级域名
  • .NET/C# 阻止屏幕关闭,阻止系统进入睡眠状态
  • .NET:自动将请求参数绑定到ASPX、ASHX和MVC(菜鸟必看)
  • .one4-V-XXXXXXXX勒索病毒数据怎么处理|数据解密恢复
  • @Async 异步注解使用
  • [2019/05/17]解决springboot测试List接口时JSON传参异常
  • [AI]文心一言爆火的同时,ChatGPT带来了这么多的开源项目你了解吗
  • [android] 看博客学习hashCode()和equals()
  • [Android] 修改设备访问权限
  • [C#]OpenCvSharp使用帧差法或者三帧差法检测移动物体