• 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
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    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:""}    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2、启动 Elasticsearch服务

    在这里插入图片描述

    3、启动SkyWalking APM服务

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

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

    在这里插入图片描述

    4、测试追踪数据持久化

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

    在这里插入图片描述

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

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

    在这里插入图片描述

    – 求知若饥,虚心若愚。

  • 相关阅读:
    Jenkins使用笔记
    Kotlin中正确的使用Handler
    Java 华为真题-选修课
    食品行业报告:豆粕市场现状研究分析与发展前景预测
    【Linux】 ls命令使用
    MATLAB线性函数拟合并预测
    swoole是怎么提高php系统的性能的
    加速LakeHouse ACID Upsert的新写时复制方案
    数据结构-堆(完全二叉树)
    riscv引导程序及仿真记录
  • 原文地址:https://blog.csdn.net/qq_42402854/article/details/126924618