This is an automated email from the ASF dual-hosted git repository.
yuanzhou pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/incubator-gluten.git
The following commit(s) were added to refs/heads/main by this push:
new f10c9fe3ed [VL] add rhel setup script support (#9863)
f10c9fe3ed is described below
commit f10c9fe3ed4583587ad12faf7fb79609d4874fa9
Author: BInwei Yang <[email protected]>
AuthorDate: Thu Jun 5 06:05:04 2025 -0700
[VL] add rhel setup script support (#9863)
Add setup-rhel.sh. Only verified on rhel9.6 now.
---
dev/build_helper_functions.sh | 9 +
ep/build-velox/src/get_velox.sh | 8 +
ep/build-velox/src/setup-rhel.sh | 395 +++++++++++++++++++++++++++++++++++++++
3 files changed, 412 insertions(+)
diff --git a/dev/build_helper_functions.sh b/dev/build_helper_functions.sh
index 3d1618794a..882c3734e8 100644
--- a/dev/build_helper_functions.sh
+++ b/dev/build_helper_functions.sh
@@ -213,6 +213,15 @@ function setup_linux {
exit 1
;;
esac
+ elif [[ "$LINUX_DISTRIBUTION" == "rhel" ]]; then
+ case "$LINUX_VERSION_ID" in
+ 9.6)
+ $GLUTEN_VELOX_SCRIPT_HOME/setup-rhel.sh ;;
+ *)
+ echo "Unsupported rhel version: $LINUX_VERSION_ID"
+ exit 1
+ ;;
+ esac
else
echo "Unsupported linux distribution: $LINUX_DISTRIBUTION"
exit 1
diff --git a/ep/build-velox/src/get_velox.sh b/ep/build-velox/src/get_velox.sh
index e144cece4b..322d08a972 100755
--- a/ep/build-velox/src/get_velox.sh
+++ b/ep/build-velox/src/get_velox.sh
@@ -233,6 +233,14 @@ function setup_linux {
exit 1
;;
esac
+ elif [[ "$LINUX_DISTRIBUTION" == "rhel" ]]; then
+ case "$LINUX_VERSION_ID" in
+ 9.6) ;;
+ *)
+ echo "Unsupported openEuler version: $LINUX_VERSION_ID"
+ exit 1
+ ;;
+ esac
else
echo "Unsupported linux distribution: $LINUX_DISTRIBUTION"
exit 1
diff --git a/ep/build-velox/src/setup-rhel.sh b/ep/build-velox/src/setup-rhel.sh
new file mode 100644
index 0000000000..f30a937784
--- /dev/null
+++ b/ep/build-velox/src/setup-rhel.sh
@@ -0,0 +1,395 @@
+#!/bin/bash
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+# This script documents setting up a Centos8 host for Velox
+# development. Running it should make you ready to compile.
+#
+#
+# Environment variables:
+# * INSTALL_PREREQUISITES="N": Skip installation of packages for build.
+# * PROMPT_ALWAYS_RESPOND="n": Automatically respond to interactive prompts.
+# Use "n" to never wipe directories.
+#
+# You can also run individual functions below by specifying them as arguments:
+# $ scripts/setup-rhel.sh install_googletest install_fmt
+#
+
+set -efx -o pipefail
+# Some of the packages must be build with the same compiler flags
+# so that some low level types are the same size. Also, disable warnings.
+SCRIPTDIR=./scripts
+source $SCRIPTDIR/setup-helper-functions.sh
+NPROC=${BUILD_THREADS:-$(getconf _NPROCESSORS_ONLN)}
+export CXXFLAGS=$(get_cxx_flags) # Used by boost.
+export CFLAGS=${CXXFLAGS//"-std=c++17"/} # Used by LZO.
+CMAKE_BUILD_TYPE="${BUILD_TYPE:-Release}"
+VELOX_BUILD_SHARED=${VELOX_BUILD_SHARED:-"OFF"} #Build folly and gflags shared
for use in libvelox.so.
+BUILD_DUCKDB="${BUILD_DUCKDB:-true}"
+USE_CLANG="${USE_CLANG:-false}"
+export INSTALL_PREFIX=${INSTALL_PREFIX:-"/usr/local"}
+DEPENDENCY_DIR=${DEPENDENCY_DIR:-$(pwd)/deps-download}
+SUDO="${SUDO:-""}"
+EXTRA_ARROW_OPTIONS=${EXTRA_ARROW_OPTIONS:-""}
+
+
+FB_OS_VERSION="v2024.07.01.00"
+FMT_VERSION="10.1.1"
+BOOST_VERSION="boost-1.84.0"
+THRIFT_VERSION="v0.16.0"
+# Note: when updating arrow check if thrift needs an update as well.
+ARROW_VERSION="15.0.0"
+STEMMER_VERSION="2.2.0"
+DUCKDB_VERSION="v0.8.1"
+FB_ZSTD_VERSION="1.5.6"
+DBL_CONVERSION_VERSION="v3.3.0"
+SODIUM_VERSION="libsodium-1.0.20-stable"
+FLEX_VERSION="2.6.4"
+DWARF_VERSION="0.11.1"
+BISON_VERSION="bison-3.8.2"
+RAPIDJSON_VERSION="v1.1.0"
+RE2_VERSION="2023-03-01"
+
+function dnf_install {
+ dnf install -y -q --setopt=install_weak_deps=False "$@"
+}
+
+function install_clang15 {
+ dnf_install clang15 gcc-toolset-13-libatomic-devel
+}
+
+# Install packages required for build.
+function install_build_prerequisites {
+ dnf update -y
+ dnf_install dnf-plugins-core
+ dnf_install ninja-build cmake gcc-toolset-12 git wget which bzip2
+ dnf_install autoconf automake python3-devel pip libtool
+ dnf install libxml2-devel
+
+ pip install cmake==3.28.3
+
+ if [[ ${USE_CLANG} != "false" ]]; then
+ install_clang15
+ fi
+}
+
+# Install dependencies from the package managers.
+function install_velox_deps_from_dnf {
+ dnf_install libevent-devel \
+ openssl-devel lz4-devel curl-devel libicu-devel zlib-devel
+ # install sphinx for doc gen
+ pip install sphinx sphinx-tabs breathe sphinx_rtd_theme
+}
+
+function install_gflags {
+ # Remove an older version if present.
+ dnf remove -y gflags
+ wget_and_untar https://github.com/gflags/gflags/archive/v2.2.2.tar.gz gflags
+ cmake_install_dir gflags -DBUILD_SHARED_LIBS=ON -DBUILD_STATIC_LIBS=ON
-DBUILD_gflags_LIB=ON -DLIB_SUFFIX=64
+}
+
+function install_glog {
+ wget_and_untar https://github.com/google/glog/archive/v0.6.0.tar.gz glog
+ cmake_install_dir glog -DBUILD_SHARED_LIBS=ON
+}
+
+function install_lzo {
+ wget_and_untar
http://www.oberhumer.com/opensource/lzo/download/lzo-2.10.tar.gz lzo
+ (
+ cd ${DEPENDENCY_DIR}/lzo
+ ./configure --prefix=${INSTALL_PREFIX} --enable-shared --disable-static
--docdir=/usr/share/doc/lzo-2.10
+ make "-j${NPROC}"
+ make install
+ )
+}
+
+function install_boost {
+ wget_and_untar
https://github.com/boostorg/boost/releases/download/${BOOST_VERSION}/${BOOST_VERSION}.tar.gz
boost
+ (
+ cd ${DEPENDENCY_DIR}/boost
+ if [[ ${USE_CLANG} != "false" ]]; then
+ ./bootstrap.sh --prefix=${INSTALL_PREFIX} --with-toolset="clang-15"
+ # Switch the compiler from the clang-15 toolset which doesn't exist
(clang-15.jam) to
+ # clang of version 15 when toolset clang-15 is used.
+ # This reconciles the project-config.jam generation with what the b2
build system allows for customization.
+ sed -i 's/using clang-15/using clang : 15/g' project-config.jam
+ ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi toolset=clang-15
--without-python
+ else
+ ./bootstrap.sh --prefix=${INSTALL_PREFIX}
+ ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi --without-python
+ fi
+ )
+}
+
+function install_snappy {
+ wget_and_untar https://github.com/google/snappy/archive/1.1.8.tar.gz snappy
+ cmake_install_dir snappy -DSNAPPY_BUILD_TESTS=OFF
+}
+
+function install_fmt {
+ wget_and_untar https://github.com/fmtlib/fmt/archive/${FMT_VERSION}.tar.gz
fmt
+ cmake_install_dir fmt -DFMT_TEST=OFF
+}
+
+function install_protobuf {
+ wget_and_untar
https://github.com/protocolbuffers/protobuf/releases/download/v21.8/protobuf-all-21.8.tar.gz
protobuf
+ (
+ cd ${DEPENDENCY_DIR}/protobuf
+ ./configure CXXFLAGS="-fPIC" --prefix=${INSTALL_PREFIX}
+ make "-j${NPROC}"
+ make install
+ ldconfig
+ )
+}
+
+function install_fizz {
+ wget_and_untar
https://github.com/facebookincubator/fizz/archive/refs/tags/${FB_OS_VERSION}.tar.gz
fizz
+ cmake_install_dir fizz/fizz -DBUILD_TESTS=OFF
+}
+
+function install_folly {
+ wget_and_untar
https://github.com/facebook/folly/archive/refs/tags/${FB_OS_VERSION}.tar.gz
folly
+ cmake_install_dir folly -DBUILD_SHARED_LIBS="$VELOX_BUILD_SHARED"
-DBUILD_TESTS=OFF -DFOLLY_HAVE_INT128_T=ON
+}
+
+function install_wangle {
+ wget_and_untar
https://github.com/facebook/wangle/archive/refs/tags/${FB_OS_VERSION}.tar.gz
wangle
+ cmake_install_dir wangle/wangle -DBUILD_TESTS=OFF
+}
+
+function install_fbthrift {
+ wget_and_untar
https://github.com/facebook/fbthrift/archive/refs/tags/${FB_OS_VERSION}.tar.gz
fbthrift
+ cmake_install_dir fbthrift -Denable_tests=OFF -DBUILD_TESTS=OFF
-DBUILD_SHARED_LIBS=OFF
+}
+
+function install_mvfst {
+ wget_and_untar
https://github.com/facebook/mvfst/archive/refs/tags/${FB_OS_VERSION}.tar.gz
mvfst
+ cmake_install_dir mvfst -DBUILD_TESTS=OFF
+}
+
+function install_duckdb {
+ if $BUILD_DUCKDB ; then
+ echo 'Building DuckDB'
+ wget_and_untar
https://github.com/duckdb/duckdb/archive/refs/tags/${DUCKDB_VERSION}.tar.gz
duckdb
+ cmake_install_dir duckdb -DBUILD_UNITTESTS=OFF -DENABLE_SANITIZER=OFF
-DENABLE_UBSAN=OFF -DBUILD_SHELL=OFF -DEXPORT_DLL_SYMBOLS=OFF
-DCMAKE_BUILD_TYPE=Release
+ fi
+}
+
+function install_stemmer {
+ wget_and_untar
https://github.com/snowballstem/snowball/archive/refs/tags/v${STEMMER_VERSION}.tar.gz
stemmer
+ (
+ cd ${DEPENDENCY_DIR}/stemmer
+ sed -i '/CPPFLAGS=-Iinclude/ s/$/ -fPIC/' Makefile
+ make clean && make "-j${NPROC}"
+ ${SUDO} cp libstemmer.a ${INSTALL_PREFIX}/lib/
+ ${SUDO} cp include/libstemmer.h ${INSTALL_PREFIX}/include/
+ )
+}
+
+function install_thrift {
+ wget_and_untar
https://github.com/apache/thrift/archive/${THRIFT_VERSION}.tar.gz thrift
+ (
+ cd ${DEPENDENCY_DIR}/thrift
+ ./bootstrap.sh
+ EXTRA_CXXFLAGS="-O3 -fPIC"
+ # Clang will generate warnings and they need to be suppressed, otherwise
the build will fail.
+ if [[ ${USE_CLANG} != "false" ]]; then
+ EXTRA_CXXFLAGS="-O3 -fPIC -Wno-inconsistent-missing-override
-Wno-unused-but-set-variable"
+ fi
+ ./configure --prefix=${INSTALL_PREFIX} --enable-tests=no
--enable-tutorial=no --with-boost=${INSTALL_PREFIX}
CXXFLAGS="${EXTRA_CXXFLAGS}" LDFLAGS="-L${INSTALL_PREFIX}/lib"
+ make "-j${NPROC}" install
+ )
+}
+
+function install_re2 {
+ wget_and_untar
https://github.com/google/re2/archive/refs/tags/${RE2_VERSION}.tar.gz re2
+ cmake_install_dir re2
+}
+
+function install_zstd {
+ wget_and_untar
https://github.com/facebook/zstd/releases/download/v${FB_ZSTD_VERSION}/zstd-${FB_ZSTD_VERSION}.tar.gz
zstd
+ (
+ cd ${DEPENDENCY_DIR}/zstd
+ make "-j${NPROC}"
+ make install PREFIX=${INSTALL_PREFIX}
+ )
+}
+
+function install_elfutils-libelf {
+ DIR="elfutils-libelf"
+ TARFILE="elfutils-latest.tar.bz2"
+ pushd "${DEPENDENCY_DIR}"
+ if [ -d "${DIR}" ]; then
+ rm -rf "${DIR}"
+ fi
+ mkdir -p "${DIR}"
+ pushd "${DIR}"
+ curl -L "https://sourceware.org/elfutils/ftp/elfutils-latest.tar.bz2" >
"${TARFILE}"
+ tar -xj --strip-components=1 -f "${TARFILE}"
+ ./configure --disable-demangler --disable-test --disable-doc
--prefix=${INSTALL_PREFIX}
+ make "-j${NPROC}"
+ make install
+ popd
+ popd
+}
+
+function install_double_conversion {
+ wget_and_untar
https://github.com/google/double-conversion/archive/refs/tags/${DBL_CONVERSION_VERSION}.tar.gz
double-conversion
+ cmake_install_dir double-conversion -DBUILD_TESTING=OFF
+}
+
+function install_libsodium {
+ wget_and_untar
https://download.libsodium.org/libsodium/releases/${SODIUM_VERSION}.tar.gz
libsodium
+ (
+ cd ${DEPENDENCY_DIR}/libsodium
+ ./configure --prefix=${INSTALL_PREFIX}
+ make "-j${NPROC}"
+ make install
+ )
+}
+
+function install_flex {
+ wget_and_untar
https://github.com/westes/flex/releases/download/v${FLEX_VERSION}/flex-${FLEX_VERSION}.tar.gz
flex
+ (
+ cd ${DEPENDENCY_DIR}/flex
+ ./configure --prefix=${INSTALL_PREFIX}
+ make "-j${NPROC}"
+ make install
+ )
+}
+
+function install_libdwarf {
+ wget_and_untar
https://github.com/davea42/libdwarf-code/archive/refs/tags/v${DWARF_VERSION}.tar.gz
libdwarf
+ (
+ cmake_install_dir libdwarf
+ )
+}
+
+function install_bison {
+ wget_and_untar https://ftp.gnu.org/gnu/bison/${BISON_VERSION}.tar.gz bison
+ (
+ cd ${DEPENDENCY_DIR}/bison
+ ./configure --prefix=${INSTALL_PREFIX}
+ make "-j${NPROC}"
+ make install
+ )
+}
+
+function install_conda {
+ CPU_ARCH=$(uname -m)
+ if [[ "$CPU_ARCH" == "amd64" ]]; then
+ CPU_ARCH="x86_64"
+ fi
+ mkdir -p ${DEPENDENCY_DIR}/miniconda3
+ curl
https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-${CPU_ARCH}.sh -o
${DEPENDENCY_DIR}/miniconda3/miniconda.sh
+ bash ${DEPENDENCY_DIR}/miniconda3/miniconda.sh -b -u -p ~/miniconda3
+ source ~/miniconda3/bin/activate
+ conda init --all
+}
+
+function install_rapidjson {
+ wget_and_untar
https://github.com/Tencent/rapidjson/archive/refs/tags/${RAPIDJSON_VERSION}.tar.gz
rapidjson
+ (
+ cmake_install_dir rapidjson \
+ -DRAPIDJSON_BUILD_DOC=OFF \
+ -DRAPIDJSON_BUILD_EXAMPLES=OFF \
+ -DRAPIDJSON_BUILD_TESTS=OFF
+ )
+}
+
+function install_c-ares {
+ github_checkout c-ares/c-ares v1.34 --depth 1
+ cmake_install -DCMAKE_BUILD_TYPE=Release
+}
+
+function install_cuda {
+ # See https://developer.nvidia.com/cuda-downloads
+ dnf config-manager --add-repo
https://developer.download.nvidia.com/compute/cuda/repos/rhel9/x86_64/cuda-rhel9.repo
+ local dashed="$(echo $1 | tr '.' '-')"
+ dnf install -y cuda-nvcc-$dashed cuda-cudart-devel-$dashed
cuda-nvrtc-devel-$dashed cuda-driver-devel-$dashed
+}
+
+function install_velox_deps {
+ run_and_time install_velox_deps_from_dnf
+ run_and_time install_conda
+ run_and_time install_re2
+ run_and_time install_double_conversion
+ run_and_time install_libdwarf
+ run_and_time install_flex
+ run_and_time install_libsodium
+ run_and_time install_elfutils-libelf
+ run_and_time install_zstd
+ run_and_time install_bison
+ run_and_time install_rapidjson
+ run_and_time install_c-ares
+ run_and_time install_gflags
+ run_and_time install_glog
+ run_and_time install_lzo
+ run_and_time install_snappy
+ run_and_time install_boost
+ run_and_time install_protobuf
+ run_and_time install_fmt
+ run_and_time install_folly
+ run_and_time install_fizz
+ run_and_time install_wangle
+ run_and_time install_mvfst
+ run_and_time install_fbthrift
+ run_and_time install_duckdb
+ run_and_time install_stemmer
+ run_and_time install_thrift
+}
+
+(return 2> /dev/null) && return # If script was sourced, don't run commands.
+
+(
+ if [[ $# -ne 0 ]]; then
+ if [[ ${USE_CLANG} != "false" ]]; then
+ export CC=/usr/bin/clang-15
+ export CXX=/usr/bin/clang++-15
+ else
+ # Activate gcc12; enable errors on unset variables afterwards.
+ source /opt/rh/gcc-toolset-12/enable || exit 1
+ set -u
+ fi
+
+ for cmd in "$@"; do
+ run_and_time "${cmd}"
+ done
+ echo "All specified dependencies installed!"
+ else
+ if [ "${INSTALL_PREREQUISITES:-Y}" == "Y" ]; then
+ echo "Installing build dependencies"
+ run_and_time install_build_prerequisites
+ else
+ echo "Skipping installation of build dependencies since
INSTALL_PREREQUISITES is not set"
+ fi
+ if [[ ${USE_CLANG} != "false" ]]; then
+ export CC=/usr/bin/clang-15
+ export CXX=/usr/bin/clang++-15
+ else
+ # Activate gcc12; enable errors on unset variables afterwards.
+ source /opt/rh/gcc-toolset-12/enable || exit 1
+ set -u
+ fi
+ install_velox_deps
+ echo "All dependencies for Velox installed!"
+ if [[ ${USE_CLANG} != "false" ]]; then
+ echo "To use clang for the Velox build set the CC and CXX environment
variables in your session."
+ echo " export CC=/usr/bin/clang-15"
+ echo " export CXX=/usr/bin/clang++-15"
+ fi
+ dnf clean all
+ fi
+)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]