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服务,发现验证追踪数据还在。

在这里插入图片描述

– 求知若饥,虚心若愚。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值