CentOS6 x64下编译TiDB
TiDB由三部分组成:tidb(SQL解析引擎)、tikv(存储引擎)、pd(placement driver,提供时间戳服务和系统拓扑维护)。其中tidb和pd用go语言开发,tikv用rust语言开发。
官方要求TiDB在CentOS7中使用,但有时确实需要在CentOS6及以下部署,此时可根据如下方式编译:
1. 配置编译环境
- 为了提高从外网下载yum包的速度,我们可先指定国内yum镜像:
# yum install epel-release
- 安装cmake3
# yum install cmake3
# ln -s /usr/bin/cmake3 /usr/bin/cmake
- 编译并安装 gcc-4.8.5
- 安装golang语言:
# yum install golang golang-docs
- 安装rust语言:
https://www.rust-lang.org/en-US/other-installers.html
从中找到相应平台的nightly版本(后面编译tikv需要此版本的rust),将url中的www.rust-lang.org替换成mirrors.ustc.edu.cn/rust-static,下载解压并安装:
# wget https://mirrors.ustc.edu.cn/rust-static/dist/rust-nightly-x86_64-unknown-linux-gnu.tar.gz && tar zxf rust-nightly-x86_64-unknown-linux-gnu.tar.gz
# cd rust-nightly-x86_64-unknown-linux-gnu && ./install.sh
- 在.bash_profile中加入:
export GOROOT=/usr/lib/golang export GOBIN=$GOROOT/bin export GOARCH=amd64 export GOOS=linux export GOPATH=/home/xxx/go export RUSTUP_DIST_SERVER=https://mirrors.ustc.edu.cn/rust-static export RUSTUP_UPDATE_ROOT=https://mirrors.ustc.edu.cn/rust-static/rustup ### 分别对应gcc-4.8.5、rust-nightly、go的路径 export PATH=/opt/xxx/bin:/usr/local/bin:$GOBIN:$GOPKG:$PATH
并导入这些环境变量:
# . ~/.bash_profile
- 创建源代码编译路径
### 注意:这一步很重要,必须确保是正确的GO src路径:
# mkdir -p $GOPATH/src/github.com/pingcap/
2. 编译tidb
# cd $GOPATH/src/github.com/pingcap
# git clone https://github.com/pingcap/tidb.git && gmake
3. 编译pd
# cd $GOPATH/src/github.com/pingcap
# git clone https://github.com/pingcap/pd.git && gmake
4. 编译tikv
编译tikv需要rust nightly版本,gcc-4.8.5(其他版本可能会在编译过程碰到问题)
# cd $GOPATH/src/github.com/pingcap
# git clone https://github.com/pingcap/tikv.git && cargo build