SkyWalking 源码分析 Collector Storage 存储组件
1. 概述
本文主要分享 SkyWalking Collector Storage 存储组件。顾名思义,负责将调用链路、应用、应用实例等等信息存储到存储器,例如,ES 、H2 。
> 友情提示:建议先阅读 《SkyWalking 源码分析 —— Collector 初始化》 ,以了解 Collector 组件体系。
> FROM https://github.com/apache/incubating-skywalking
>
> 
下面我们来看看整体的项目结构,如下图所示 :

- apm-collector-core 的 data 和 define 包 :数据的抽象。
- collector-storage-define :定义存储组件接口。
- collector-storage-h2-provider :基于 H2 的 存储组件实现。该实现是单机版,建议仅用于 SkyWalking 快速上手,生产环境不建议使用。
- collector-storage-es-provider :基于 Elasticsearch 的集群管理实现。生产环境推荐使用。
下面,我们从接口到实现的顺序进行分享。
2. apm-collector-core
apm-collector-core 的 data 和 define 包,如下图所示:
