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服务,发现验证追踪数据还在。
– 求知若饥,虚心若愚。