架构
计算层
Broker,是一个无状态的服务,具有水平扩容能力。 其中,Master 是承担特殊职责的节点,所有的 Metadata 变更均由 Master 来完成,以保证一致性,Master 可以从任一 Broker 节点中抢占式选举产生。
Broker 的主要职责如下:
- 负载均衡:由于自身无状态,可以启动多个实例,因此接入层的连接可以均匀的分摊到所有 Broker 节点上进行读写;
- WAL复制: 由Master节点负责将相应的WAL日志复制到对应的Slave节点;
- 分布式查询:根据具体的查询情况生成不同的执行计划;
- 查询结果聚合:作为计算层聚合 Broker(中间查询)/Storage 查询返回的数据;
- 跨机房查询结果聚合:多IDC查询结果的再聚合;
存储层
Storage, 也是一个无状态的服务,只存储实际的数据,不存储整个 Storage 集群的 Metadata,因此也具有水平扩展的能力。主要职责如下:
- 写入:存储各database下的数据及索引,以及自己的 Metadata;
- 读取:执行数据的过滤及一些简单的聚合操作(最原子的field基本类型的聚合计算);
- DDL:执行 Broker 下发的 Metadata 变更任务,如创建数据库,数据治理等;
- 自监控:定期上报自身服务的状态;
元信息系统层
ETCD是 LinDB 的唯一外部依赖,ETCD 也是一个弱依赖,即在不可用的情况下,LinDB 集群仍然可以提供服务。
ETCD 主要职责如下:
- 元数据存储:如数据库的配置,各分片的信息,Broker/Storage 集群各节点的状态;
- 分布式调度:即所有的 Metadata 的变更都通过 ETCD 中转下发到 Storage 节点;
实现弱依赖的前置条件:
- 当 ETCD 出问题的时候,不存在 Metadata 信息的变更,如不修改数据库的配置等;
- 集群状态是健康的,即还是可以使用当前的 Metadata/Status 来协调整个集群;
一定的自修复能力:当 ETCD 中的数据完整不可用或者丢失时,Broker/Storage 可以上报 Metadata/Status 到新的 ETCD 集群以实现故障转移;