Skip to content

Latest commit

 

History

History
231 lines (156 loc) · 4.63 KB

BUILD.md

File metadata and controls

231 lines (156 loc) · 4.63 KB

Build From Source

Proton requires the Clang compiler and related LLVM toolchain. GCC is not supported.

Ubuntu/Debian Linux - x86

Build with docker container

./docker/packager/packager --package-type binary --docker-image-version clang-17 --proton-build --enable-proton-local --output-dir `pwd`/build_output

Bare metal build

Install toolchain

  • clang-17 /clang++-17 or above (minimum supported version: Clang 16, GCC not supported)
  • cmake 3.20 or above
  • ninja
apt install git cmake ccache python3 ninja-build wget apt-transport-https apt-utils ca-certificates dnsutils gnupg iputils-ping lsb-release gpg curl software-properties-common

install llvm-17 compiler

wget https://apt.llvm.org/llvm.sh
chmod +x llvm.sh
sudo ./llvm.sh 17

Build

$ git clone --recurse-submodules git@github.com:timeplus-io/proton.git
$ cd proton
$ mkdir -p build && cd build && cmake ..
$ ninja

Issue: Could NOT find Threads (missing: Threads_FOUND)

Possible Solution:

  1. Install the required packages:

    apt-get install -y build-essential cmake libc6-dev libpthread-stubs0-dev linux-libc-dev
  2. Clean the build folder and rerun the CMake command.

Redhat Linux - x86

Build with docker container

Bare metal build

Install toolchain

  • clang-17 /clang++-17 or above
  • cmake 3.20 or above
  • ninja

Build

$ git clone --recurse-submodules git@github.com:timeplus-io/proton.git
$ cd proton
$ mkdir -p build && cd build && cmake ..
$ ninja

Ubuntu Linux - ARM

Build with docker container

Bare metal build

Install toolchain

  • clang-17 /clang++-17 or above
  • cmake 3.20 or above
  • ninja

Build

$ git clone --recurse-submodules git@github.com:timeplus-io/proton.git
$ cd proton
$ mkdir -p build && cd build && cmake ..
$ ninja

Redhat Linux - ARM

Build with docker container

Bare metal build

Install toolchain

  • clang-17 /clang++-17 or above
  • cmake 3.20 or above
  • ninja

Build

$ git clone --recurse-submodules git@github.com:timeplus-io/proton.git
$ cd proton
$ mkdir -p build && cd build && cmake ..
$ ninja

MacOS - Intel Architecture

Build with docker container

Not supported.

Bare metal build

Install toolchain

We don't support build Proton by using Apple Clang. Please use brew install llvm to install clang-17 / clang++-17.

  • clang-17 /clang++-17 or above
  • cmake 3.20 or above
  • ninja

Build

$ git clone --recurse-submodules git@github.com:timeplus-io/proton.git
$ cd proton
$ mkdir -p build && cd build && cmake ..
$ ninja

MacOS - Apple Silicon

Build with docker container

Not supported.

Bare metal build

Step 1: Verify Xcode Version for macOS

Ensure you have the correct version of Xcode installed:

  • Version 14.3.1
  • Or any version newer than 15.1.Beta.1.

To check your Xcode version, run the following command:

/Applications/Xcode.app/Contents/Developer/usr/bin/xcodebuild -version

You should receive an output similar to:

Xcode 14.3.1
Build version 14E300c

Or, for newer versions:

Xcode 15.1
Build version 15C5042i

Step 2: Install Dependencies with Homebrew

Proton build is not supported with Apple Clang. Use Homebrew to install LLVM version 17 instead:

brew install llvm@17

First, if you haven't installed Homebrew yet, follow the instructions at https://brew.sh/.

Next, install the required dependencies using the following commands:

brew update
brew install ccache cmake ninja libtool gettext llvm@17 gcc binutils grep findutils libiconv

Step 3: Build Proton Manually

Set up the environment variables required for building Proton:

export PATH=$(brew --prefix llvm@17)/bin:$PATH
export CC=$(brew --prefix llvm@17)/bin/clang
export CXX=$(brew --prefix llvm@17)/bin/clang++

Clone the Proton repository and initiate the build process:

git clone --recurse-submodules git@github.com:timeplus-io/proton.git
cd proton
mkdir -p build && cd build
cmake ..
ninja

Run proton binary locally

Enter Proton binary folder and run Proton server

You can either launch the server with a self-modified(especially the path) YAML file or start it without specifying the config file (This way will store the data in current path).

$ cd proton/build
$ ./programs/proton server --config-file ../programs/server/config.yaml
$ ./programs/proton server start

In another console, run Proton client

$ cd proton/build
$ ./programs/proton client

Then follow Timeplus user documents to create stream, insert data and run queries.