# 鲲鹏 ARM 架构编译 ClickHouse 记录(最全)
[TOC]
# 环境要求
软硬件 参数
CPU 鲲鹏 920
内存 >= 8GB
硬盘 >= 100GB(编译 CK会占用 60GB)
CentOS 7.6
GCC 9.3.0
CMake 3.18.4
ClickHouse v20.3.19.4-lts
# Yum 安装相关依赖
yum -y install lz4-devel openssl-devel zlib-devel zstd-devel protobufdevel libicu-devel readline-devel gperf curl-devel
# 升级 GCC 到 9.3.0
CentOS 7.6 系统自带的 GCC 版本是 4.8.5,需要手动编译升级,无需重新安装
mkdir -p /opt/gcc-pkg
cd /opt/gcc-pkg
wget https://mirrors.tuna.tsinghua.edu.cn/gnu/gcc/gcc-9.3.0/gcc-9.3.0.tar.gz
tar -zxvf gcc-9.3.0.tar.gz
cd gcc-9.3.0/
#在下载依赖包时需要先下载这个插件,要不会报错
yum install -y lbzip2
下载gmp mpfr mpc等供编译需求的依赖项
./contrib/download_prerequisites
创建一个新的目录,并在此目录编译安装,不推荐在源码目录操作
mkdir build && cd build
配置参数(参数含义见下)
../configure --prefix=/usr/local/gcc-9.3.0 --enable-bootstrap --enable-checking=release --enable-languages=c,c++ --disable-multilib
编译生成 makefile 文件,开 4 个进程进行编译
make -j 4
安装 GCC
sudo make install
设置环境变量
vim /etc/profile
添加以下配置
export LD_LIBRARY_PATH=/usr/local/lib:/usr/lib:/usr/local/lib64:/usr/lib64
export CC=/usr/local/gcc-9.3.0/bin/aarch64-unknown-linux-gnu-gcc
export CXX=/usr/local/gcc-9.3.0/bin/aarch64-unknown-linux-gnu-g++
export PATH=/usr/local/gcc-9.3.0/bin:${PATH}
设置头文件
sudo ln -sv /usr/local/gcc/include/ /usr/include/gcc
设置库文件
touch /etc/ld.so.conf.d/gcc.conf
sudo chmod 777 /etc/ld.so.conf.d/gcc.conf
sudo echo -e "/usr/local/gcc/lib64" >> /etc/ld.so.conf.d/gcc.conf
加载动态连接库
sudo ldconfig -v
ldconfig -p | grep gcc
测试
gcc --version
gcc -v
–enable-languages表示你要让你的gcc支持哪些编程语言;
–disable-multilib表示编译器不编译成其他平台的可执行代码;
–disable-checking表示生成的编译器在编译过程中不做额外检查
–enable-checking=xxx 表示编译过程中增加XXX检查
–prefix=/usr/local/gcc-9.3.0 指定安装路径
–enable-bootstrap 表示用第一次编译生成的程序进行第二次编译,然后用再次生成的程序进行第三次编译,并且检查比较第二次和第三次结果的正确性,也就是进行冗余的编译检查工作。 非交叉编译环境下,默认已经将该值设为 enable,可以不用显示指定;交叉编译环境下,需要显示将其值设为 disable。
# 坑 1:GCC 更新后,系统库也要更新
在把 GCC 更新到 9.3.0 后也需要把系统库更新到与 GCC 相对应的版本,要不在后面编译安装 CMake 的时候会报 libstdc++.so.6: version 'GLIBCXX_3.4.20' not found 或者其他版本错误,解决方案:
cp /usr/local/gcc-9.3.0/lib64/libstdc++.so.6.0.28 /usr/lib64
cd /usr/lib64
ln -s libstdc++.so.6 libstdc++.so.6.0.28
检查是否包含 GLIBCXX_3.4.* 版本
strings /usr/lib64/libstdc++.so.6 | grep GLIBCXX
GLIBCXX_3.4
GLIBCXX_3.4.1
GLIBCXX_3.4.2
GLIBCXX_3.4.3
GLIBCXX_3.4.4
GLIBCXX_3.4.5
GLIBCXX_3.4.6
GLIBCXX_3.4.7
GLIBCXX_3.4.8
GLIBCXX_3.4.9
GLIBCXX_3.4.10
GLIBCXX_3.4.11
GLIBCXX_3.4.12
GLIBCXX_3.4.13
GLIBCXX_3.4.14
GLIBCXX_3.4.15
GLIBCXX_3.4.16
GLIBCXX_3.4.17
GLIBCXX_3.4.18
GLIBCXX_3.4.19
GLIBCXX_3.4.20
GLIBCXX_3.4.21
GLIBCXX_3.4.22
GLIBCXX_3.4.23
GLIBCXX_3.4.24
GLIBCXX_3.4.25
GLIBCXX_3.4.26
GLIBCXX_3.4.27
GLIBCXX_3.4.28
# 编译安装 CMake
cmake 用于编译 Ck
mkdir -p /opt/cmake-pkg
cd /opt/cmake-pkg
wget https://github.com/Kitware/CMake/archive/v3.18.4.tar.gz
cd cmake-3.18.4
./bootstrap
编译安装
make -j 4
make install
查看版本
cmake --version
# 编译安装 Git
没有就安装,有就升级
先安装这个依赖,不然在后面 git clone 时会报 https 错误
yum install -y curl-devel
mkdir -p /opt/git-pkg
cd /opt/git-pkg
wget https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.28.0.tar.gz
tar -zxvf git-2.28.0.tar.gz
cd git-2.28.0
编译安装
./configure --prefix=/usr/local
make -j 4
make install
查看 git 版本
git --version
# 编译安装 ClickHouse
## 从 GitHub 克隆
这里需要注意一下,克隆下来的 ClickHouse 是很干净的,没有其他依赖的,但是编译 ClickHouse 需要相关的子依赖和父依赖,所以需要运行命令 git submodule update --init –recursive 这个命令会把相关的依赖都下载下来,但是有些依赖是在国外的服务器上的,比如 Google Git 上,国内网络无法访问,所以会导致报错,解决方案有三个:
在 git 上开代理,直接访问国外的代码仓库(亲测没成功)
在本机上开代理,使用全局代理(亲测没成功)
购买国外服务器,可以直接访问国外的代码仓库(亲测可用,要花点钱,可以使用 Vultr 平台,按量付费,用完把实例删掉即可)
提供网盘下载:链接,提取码:1nwb,该版本是 v20.3.19.4-lts 的完整源码
这里是在国外服务器上的操作,如果下载的是网盘链接里面的文件直接跳过这步
git clone https://github.com/ClickHouse/ClickHouse.git
git checkout v20.3.19.4-lts
git submodule update --init –recursive
开始准备编译操作
由于各种原因无法将下载完成的包快速下载,SFTP 速度过慢,可以使用 HTTP 服务下载
先安装 HTTP 服务组件
yum install -y httpd
关闭防火墙,因为这个服务器只是用来下载工具的,用完就删了,没必要在意安全问题
systemctl stop filewalld
直接打开 HTTP 服务,无需配置,默认 80 端口
systemctl start httpd
这是 HTTP 默认访问文件路径
cd /var/www/html
创建一个临时目录用于下载文件
mkdir test && cd test
复制之前先打个包,一共 3.3g
cp Ck压缩文件 ./
在本机访问地址 http://ipAddress:port/test 就可以在网页上看到文件,点击下载即可,这里还是需要在本机开个代理,要不还是很慢
下载下来后解压
tar -xzvf ClickHouse.tar.gz
## 准备编译操作
解压进入已经下载好依赖的 ClickHouse 的目录
cd ClickHouse
修改 CMakeLists 编译选项
vim CMakeLists.txt
在第一行添加以下配置,防止 Could NOT find Threads (missing: Threads_FOUND) 报错
set(CMAKE_THREAD_LIBS_INIT "-lpthread")
set(CMAKE_HAVE_THREADS_LIBRARY 1)
set(CMAKE_USE_WIN32_THREADS_INIT 0)
set(CMAKE_USE_PTHREADS_INIT 1)
set(THREADS_PREFER_PTHREAD_FLAG ON)
进入 vim 的命令模式(退出输入模式)输入:/if (WERROR) 找到该行,做如下操作
注释掉如下三行命令,禁止将警告作为错误报出
option (WERROR "Enable -Werror compiler option" OFF)
#if (WERROR)
#add_warning(error)
#endif ()
找到 set (COMPILER_FLAGS "${COMPILER_FLAGS} -march=native") 这一行,修改为
set (COMPILER_FLAGS "${COMPILER_FLAGS} -march=armv8-a")
保存退出
# 坑2:修改 ClickHouse/contrib/zlib-ng/CMakeLists.txt 文件
这个文件也需要修改,要不然会在编译阶段出现报错,根据报错信息,最终定位到这个文件
在 ClickHouse 源码目录下
vim contrib/zlib-ng/CMakeLists.txt
把所有带有 -march 的地方都改成 -march=armv8-a
# 坑3:eventfd的count参数类型与声明不符
将/usr/include/sys/eventfd.h拷贝一份新文件;
cp /usr/include/sys/eventfd.h /usr/include/sys/eventfd_new.h
找到./ClickHouse/base/glibc-compatibility/musl/eventfd.c文件,
修改头文件引入
将第一行改为
#include <sys/eventfd_new.h>
# 开始编译安装
开始编译时建议把整个 ClickHouse 文件目录放到一个比较空的磁盘,最好别是系统盘,因为编译过程中会产生 60g 的文件
在 ClickHouse 目录下执行命令
export CC=gcc; export CXX=g++; rm -rf build; mkdir -p build && cd build; cmake .. -DUSE-UNWIND=OFF -DENABLE_TCMALLOC=OFF -DENABLE_JEMALLOC=OFF -DCMAKE_INSTALL_PREFIX=/home/clickhouse
开 4 个进程进行编译(编译速度与 CPU,磁盘类型等因素有关,这里大概花了1个半小时)
make -j 4
========坑3:报错排除,继续编译。
make install
编译完成后会输出到 -DCMAKE_INSTALL_PREFIX 指定的目录,大概有 3.5g
添加环境变量
export PATH=/home/clickhouse/bin:${PATH}
export LD_LIBRARY_PATH=/home/clickhouse/lib:${LD_LIBRARY_PATH}
-DCMAKE_INSTALL_PREFIX 是安装目录
# 添加缺失文件
在编译完成后,会缺少一些文件,并不是编译错误造成的,这些文件需要手动添加
config.xml
dhparam.pem
server.crt
server.key
users.xml
config.xml 和 users.xml 文件是从源码目录复制过来的
mkdir cliclhouse/config
cp ClickHouse/programs/server/config.xml cliclhouse/config/
cp ClickHouse/programs/server/users.xml cliclhouse/config/
验证是否安装成功
clickhouse-server --version
# 测试[重要]
\#由于/etc/clickhouse-server/config.xml默认使能ssl,且证书需要手动执行,否则启动服务端时会coredump
[root@localhost ~]#openssl req -subj "/CN=localhost" -new -newkey rsa:2048 -days 365 -nodes -x509 -keyout /etc/clickhouse-server/server.key -out /etc/clickhouse-server/server.crt
[root@localhost ~]#openssl dhparam -out /etc/clickhouse-server/dhparam.pem 4096
启动clickhouse服务
[root@localhost ~]# clickhouse-server --config-file=/etc/clickhouse-server/config.xml
客户端连接数据库。
[root@localhost ~]# clickhouse-client
---结束
————————————————
参考:https://blog.csdn.net/chentyit/article/details/109227895
posted on
浙公网安备 33010602011771号