167 lines
4.7 KiB
Bash
Executable File
167 lines
4.7 KiB
Bash
Executable File
#!/usr/bin/env 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.
|
|
#
|
|
|
|
set -o pipefail
|
|
set -e
|
|
set -x
|
|
|
|
# Figure out where the RSS framework is installed
|
|
PROJECT_DIR="$(cd "`dirname "$0"`/.."; pwd)"
|
|
DIST_DIR="$PROJECT_DIR/dist"
|
|
NAME="bin"
|
|
|
|
function exit_with_usage {
|
|
echo "make-distribution.sh - tool for making binary distributions of Remote Shuffle Service"
|
|
echo ""
|
|
echo "usage:"
|
|
cl_options="[--name <custom_name>]"
|
|
echo "make-distribution.sh $cl_options <maven build options>"
|
|
echo ""
|
|
exit 1
|
|
}
|
|
|
|
# Parse arguments
|
|
while (( "$#" )); do
|
|
case $1 in
|
|
--name)
|
|
NAME="bin-$2"
|
|
shift
|
|
;;
|
|
--help)
|
|
exit_with_usage
|
|
;;
|
|
--*)
|
|
echo "Error: $1 is not supported"
|
|
exit_with_usage
|
|
;;
|
|
-*)
|
|
break
|
|
;;
|
|
*)
|
|
echo "Error: $1 is not supported"
|
|
exit_with_usage
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
MVN="$PROJECT_DIR/build/mvn"
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
# Fall back on JAVA_HOME from rpm, if found
|
|
if [ $(command -v rpm) ]; then
|
|
RPM_JAVA_HOME="$(rpm -E %java_home 2>/dev/null)"
|
|
if [ "$RPM_JAVA_HOME" != "%java_home" ]; then
|
|
JAVA_HOME="$RPM_JAVA_HOME"
|
|
echo "No JAVA_HOME set, proceeding with '$JAVA_HOME' learned from rpm"
|
|
fi
|
|
fi
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
if [ `command -v java` ]; then
|
|
# If java is in /usr/bin/java, we want /usr
|
|
JAVA_HOME="$(dirname $(dirname $(which java)))"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
echo "Error: JAVA_HOME is not set, cannot proceed."
|
|
exit -1
|
|
fi
|
|
|
|
if [ ! "$(command -v "$MVN")" ] ; then
|
|
echo -e "Could not locate Maven command: '$MVN'."
|
|
exit -1;
|
|
fi
|
|
|
|
if [ $(command -v git) ]; then
|
|
GITREV=$(git rev-parse --short HEAD 2>/dev/null || :)
|
|
if [ ! -z "$GITREV" ]; then
|
|
GITREVSTRING=" (git revision $GITREV)"
|
|
fi
|
|
unset GITREV
|
|
fi
|
|
|
|
VERSION=$("$MVN" help:evaluate -Dexpression=project.version $@ 2>/dev/null\
|
|
| grep -v "INFO"\
|
|
| grep -v "WARNING"\
|
|
| tail -n 1)
|
|
SCALA_VERSION=$("$MVN" help:evaluate -Dexpression=scala.binary.version $@ 2>/dev/null\
|
|
| grep -v "INFO"\
|
|
| grep -v "WARNING"\
|
|
| tail -n 1)
|
|
SPARK_VERSION=$("$MVN" help:evaluate -Dexpression=spark.version $@ 2>/dev/null\
|
|
| grep -v "INFO"\
|
|
| grep -v "WARNING"\
|
|
| tail -n 1)
|
|
|
|
SPARK_MAJOR_VERSION=${SPARK_VERSION%%.*}
|
|
|
|
echo "Celeborn version is $VERSION"
|
|
|
|
echo "Making celeborn-$VERSION-$NAME.tgz"
|
|
|
|
# Build uber fat JAR
|
|
cd "$PROJECT_DIR"
|
|
|
|
export MAVEN_OPTS="${MAVEN_OPTS:--Xmx2g -XX:ReservedCodeCacheSize=1g}"
|
|
|
|
# Store the command as an array because $MVN variable might have spaces in it.
|
|
# Normal quoting tricks don't work.
|
|
# See: http://mywiki.wooledge.org/BashFAQ/050
|
|
BUILD_COMMAND=("$MVN" clean package -DskipTests $@)
|
|
|
|
# Actually build the jar
|
|
echo -e "\nBuilding with..."
|
|
echo -e "\$ ${BUILD_COMMAND[@]}\n"
|
|
|
|
"${BUILD_COMMAND[@]}"
|
|
|
|
# Make directories
|
|
rm -rf "$DIST_DIR"
|
|
mkdir -p "$DIST_DIR/master-jars"
|
|
mkdir -p "$DIST_DIR/worker-jars"
|
|
mkdir -p "$DIST_DIR/spark"
|
|
|
|
echo "Celeborn $VERSION$GITREVSTRING" > "$DIST_DIR/RELEASE"
|
|
echo "Build flags: $@" >> "$DIST_DIR/RELEASE"
|
|
|
|
# Copy jars
|
|
cp "$PROJECT_DIR"/master/target/celeborn-master_$SCALA_VERSION-$VERSION.jar "$DIST_DIR/master-jars/"
|
|
cp "$PROJECT_DIR"/master/target/scala-$SCALA_VERSION/jars/*.jar "$DIST_DIR/master-jars/"
|
|
cp "$PROJECT_DIR"/worker/target/celeborn-worker_$SCALA_VERSION-$VERSION.jar "$DIST_DIR/worker-jars/"
|
|
cp "$PROJECT_DIR"/worker/target/scala-$SCALA_VERSION/jars/*.jar "$DIST_DIR/worker-jars/"
|
|
cp "$PROJECT_DIR"/client-spark/spark-$SPARK_MAJOR_VERSION/target/celeborn-client-spark-${SPARK_MAJOR_VERSION}_$SCALA_VERSION-$VERSION-shaded.jar "$DIST_DIR/spark/"
|
|
|
|
# Copy other things
|
|
mkdir "$DIST_DIR/conf"
|
|
cp "$PROJECT_DIR"/conf/*.template "$DIST_DIR/conf"
|
|
cp -r "$PROJECT_DIR/bin" "$DIST_DIR"
|
|
cp -r "$PROJECT_DIR/sbin" "$DIST_DIR"
|
|
mkdir "$DIST_DIR/docker"
|
|
cp "$PROJECT_DIR/docker/Dockerfile" "$DIST_DIR/docker"
|
|
cp -r "$PROJECT_DIR/docker/helm" "$DIST_DIR/docker"
|
|
|
|
TARDIR_NAME="celeborn-$VERSION-$NAME"
|
|
TARDIR="$PROJECT_DIR/$TARDIR_NAME"
|
|
rm -rf "$TARDIR"
|
|
cp -r "$DIST_DIR" "$TARDIR"
|
|
tar czf "celeborn-$VERSION-$NAME.tgz" -C "$PROJECT_DIR" "$TARDIR_NAME"
|
|
rm -rf "$TARDIR"
|