TiFlash 是 TiDB 的组件。它主要在 TiDB 的混合事务/分析处理(HTAP)架构中扮演分析处理(AP)的角色。 TiFlash 通过 Raft logs 实时同步 TiKV 的数据更新,延迟时间为亚秒级。TiFlash 利用大规模并行处理(MPP)计算架构来加速分析工作负载。
TiFlash 的框架代码基于 ClickHouse。
构建 TiFlash
TiFlash 支持在以下硬件架构上构建:
- x86-64/amd64
- aarch64
以及以下操作系统:
- Linux
- macOS
Checkout 源代码
假设 $WORKSPACE 是放置 TiFlash 仓库的目录。
cd $WORKSPACE git clone --recursive https://github.com/pingcap/tiflash.git
准备先决条件
所有平台都需要以下软件包:
- CMake 3.21.0+
- Rust:推荐使用 rustup 安装:
curl https://sh.rustup.rs -sSf | sh -s -- -y --profile minimal --default-toolchain nightly source $HOME/.cargo/env
- Python 3.0+
- Ninja 或 GNU Make
构建
假设 $BUILD 是你要构建 TiFlash 的目录。
对于 Ninja
cd $BUILD cmake $WORKSPACE/tiflash -Gninja ninja tiflash
对于 GNU Make:
cd $BUILD cmake $WORKSPACE/tiflash make tiflash -j
构建完成后,可以在$BUILD/dbms/src/Server/tiflash
获取 TiFlash 二进制文件