SkyWalking持久化追踪数据

编程入门 行业动态 更新时间:2024-10-11 07:29:28

SkyWalking<a href=https://www.elefans.com/category/jswz/34/1771330.html style=持久化追踪数据"/>

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

– 求知若饥,虚心若愚。

更多推荐

SkyWalking持久化追踪数据

本文发布于:2024-03-08 13:15:55,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1720982.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:持久   数据   SkyWalking

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!