Этот вариант подходит, если у вас есть машина с Linux и вы хотите использовать её для сборки бинарного файла clickhouse, который будет работать в OS X.
Основной сценарий использования — проверки непрерывной интеграции, выполняемые на машинах с Linux.
Если вы хотите собрать ClickHouse непосредственно на macOS, воспользуйтесь инструкциями по нативной сборке.
Кросс-сборка для macOS основана на инструкциях по сборке, поэтому сначала выполните их.
В следующих разделах приведено пошаговое руководство по сборке ClickHouse для macOS x86_64.
Если целевая архитектура — ARM, просто замените все вхождения x86_64 на aarch64.
Например, замените x86_64-apple-darwin на aarch64-apple-darwin на всех этапах.
Запомним путь, в который мы устанавливаем cctools, как ${CCTOOLS}
mkdir ~/cctools
export CCTOOLS=$(cd ~/cctools && pwd)
cd ${CCTOOLS}
git clone https://github.com/tpoechtrager/apple-libtapi.git
cd apple-libtapi
git checkout 15dfc2a8c9a2a89d06ff227560a69f5265b692f9
INSTALLPREFIX=${CCTOOLS} ./build.sh
./install.sh
cd ..
git clone https://github.com/tpoechtrager/cctools-port.git
cd cctools-port/cctools
git checkout 2a3e1c2a6ff54a30f898b70cfb9ba1692a55fad7
./configure --prefix=$(readlink -f ${CCTOOLS}) --with-libtapi=$(readlink -f ${CCTOOLS}) --target=x86_64-apple-darwin
make install
Также нужно скачать macOS X SDK в рабочий каталог.
cd ClickHouse/cmake/toolchain/darwin-x86_64
curl -L 'https://github.com/phracker/MacOSX-SDKs/releases/download/11.3/MacOSX11.0.sdk.tar.xz' | tar xJ --strip-components=1
cd ClickHouse
mkdir build-darwin
cd build-darwin
cmake -DCMAKE_AR:FILEPATH=${CCTOOLS}/bin/x86_64-apple-darwin-ar -DCMAKE_INSTALL_NAME_TOOL=${CCTOOLS}/bin/x86_64-apple-darwin-install_name_tool -DCMAKE_RANLIB:FILEPATH=${CCTOOLS}/bin/x86_64-apple-darwin-ranlib -DLINKER_NAME=${CCTOOLS}/bin/x86_64-apple-darwin-ld -DCMAKE_TOOLCHAIN_FILE=cmake/darwin/toolchain-x86_64.cmake ..
ninja
Полученный бинарный файл будет иметь формат исполняемого файла Mach-O и не сможет запускаться в Linux. Последнее изменение 10 июня 2026 г.