在 Mac OS X 中编译 ClickHouse

ClickHouse 支持在 Mac OS X 10.12 以及以上版本中编译。如果你在用更早的操作系统版本,可以尝试在指令中使用 Gentoo Prefixclang sl. 通过适当的更改,它应该可以适用于任何其他的 Linux 发行版。

安装 Homebrew

  1. /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

安装编译器,工具库

  1. brew install cmake ninja gcc icu4c mariadb-connector-c openssl libtool gettext readline

拉取 ClickHouse 源码

  1. git clone --recursive git@github.com:yandex/ClickHouse.git
  2. # or: git clone --recursive https://github.com/yandex/ClickHouse.git
  3. cd ClickHouse
  4. For the latest stable version, switch to the stable branch.

编译 ClickHouse

  1. mkdir build
  2. cd build
  3. cmake .. -DCMAKE_CXX_COMPILER=`which g++-8` -DCMAKE_C_COMPILER=`which gcc-8`
  4. ninja
  5. cd ..

注意事项

若你想运行 clickhouse-server ,请先确保增加系统的最大文件数配置。
!!! 注意 可能需要用 sudo
为此,请创建以下文件:

  1. /Library/LaunchDaemons/limit.maxfiles.plist:
  2. <?xml version="1.0" encoding="UTF-8"?>
  3. <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN"
  4. "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  5. <plist version="1.0">
  6. <dict>
  7. <key>Label</key>
  8. <string>limit.maxfiles</string>
  9. <key>ProgramArguments</key>
  10. <array>
  11. <string>launchctl</string>
  12. <string>limit</string>
  13. <string>maxfiles</string>
  14. <string>524288</string>
  15. <string>524288</string>
  16. </array>
  17. <key>RunAtLoad</key>
  18. <true/>
  19. <key>ServiceIPC</key>
  20. <false/>
  21. </dict>
  22. </plist>

执行以下命令:

  1. $ sudo chown root:wheel /Library/LaunchDaemons/limit.maxfiles.plist

然后重启。

可以通过 ulimit -n 命令来检查是否生效。