### What changes were proposed in this pull request? Support Flink 2.1. ### Why are the changes needed? Flink 2.1 has already released, which release notes refer to [Release notes - Flink 2.1](https://nightlies.apache.org/flink/flink-docs-master/release-notes/flink-2.1). ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? CI. Closes #3404 from SteNicholas/CELEBORN-2093. Authored-by: SteNicholas <programgeek@163.com> Signed-off-by: SteNicholas <programgeek@163.com>
270 lines
7.4 KiB
Bash
Executable File
270 lines
7.4 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 -ex
|
|
|
|
# Explicitly set locale in order to make `sort` output consistent across machines.
|
|
# See https://stackoverflow.com/questions/28881 for more details.
|
|
export LC_ALL=C
|
|
|
|
PWD=$(cd "$(dirname "$0")"/.. || exit; pwd)
|
|
|
|
MVN="${PWD}/build/mvn"
|
|
SBT="${PWD}/build/sbt"
|
|
|
|
SBT_ENABLED="false"
|
|
REPLACE="false"
|
|
CHECK="false"
|
|
MODULE=""
|
|
|
|
DEP_PR=""
|
|
DEP=""
|
|
|
|
function mvn_build_classpath() {
|
|
$MVN -P$MODULE clean install -DskipTests -am -pl $MVN_MODULES
|
|
$MVN -P$MODULE dependency:build-classpath -am -pl $MVN_MODULES | \
|
|
grep -A1 "Dependencies classpath:" | \
|
|
grep -v "^--$" | \
|
|
grep -v "Dependencies classpath:" | \
|
|
grep -v '^$' | \
|
|
tr ":" "\n" | \
|
|
awk -F '/' '{
|
|
artifact_id=$(NF-2);
|
|
version=$(NF-1);
|
|
jar_name=$NF;
|
|
classifier_start_index=length(artifact_id"-"version"-") + 1;
|
|
classifier_end_index=index(jar_name, ".jar") - 1;
|
|
classifier=substr(jar_name, classifier_start_index, classifier_end_index - classifier_start_index + 1);
|
|
print artifact_id"/"version"/"classifier"/"jar_name
|
|
}' | grep -v "celeborn" | sort -u >> "${DEP_PR}"
|
|
}
|
|
|
|
function sbt_build_client_classpath() {
|
|
PATTERN="$SBT_PROJECT / Runtime / managedClasspath"
|
|
deps=$(
|
|
$SBT -P$MODULE "clean; export Runtime/managedClasspath" | \
|
|
awk -v pat="$PATTERN" '$0 ~ pat { found=1 } found { print }' | \
|
|
awk 'NR==2' | \
|
|
tr ":" "\n"
|
|
)
|
|
sbt_process_classpath "$deps"
|
|
}
|
|
|
|
function sbt_build_server_classpath() {
|
|
deps=$(
|
|
$SBT "error; clean; export managedClasspath" | \
|
|
awk '/managedClasspath/ { found=1 } found { print }' | \
|
|
awk 'NR % 2 == 0' | \
|
|
# This will skip the last line
|
|
sed '$d' | \
|
|
tr ":" "\n"
|
|
)
|
|
sbt_process_classpath "$deps"
|
|
}
|
|
|
|
function sbt_process_classpath() {
|
|
deps1=$(echo "$deps" | grep -v ".sbt")
|
|
deps2=$(echo "$deps" | grep ".sbt" || true)
|
|
result1=$(
|
|
echo "$deps1" | \
|
|
awk -F '/' '{
|
|
artifact_id=$(NF-2);
|
|
version=$(NF-1);
|
|
jar_name=$NF;
|
|
classifier_start_index=length(artifact_id"-"version"-") + 1;
|
|
classifier_end_index=index(jar_name, ".jar") - 1;
|
|
classifier=substr(jar_name, classifier_start_index, classifier_end_index - classifier_start_index + 1);
|
|
print artifact_id"/"version"/"classifier"/"jar_name
|
|
}'
|
|
)
|
|
# TODO: a temporary workaround for parsing the dependency in the directory `.sbt`,
|
|
# need to migrate this to the SBT plugin.
|
|
version_pattern="scala-([0-9]+\.[0-9]+\.[0-9]+)"
|
|
file_pattern="/([^/]+)\.jar"
|
|
result2=()
|
|
while IFS= read -r line; do
|
|
if [[ -n "$line" ]]; then
|
|
[[ $line =~ $version_pattern ]] && version_info="${BASH_REMATCH[1]}";
|
|
[[ $line =~ $file_pattern ]] && file_name="${BASH_REMATCH[1]}";
|
|
result2+=("$file_name/$version_info//$file_name-$version_info.jar")
|
|
fi
|
|
done <<< "$deps2"
|
|
|
|
result=("${result1[@]}" "${result2[@]}")
|
|
|
|
echo "${result[@]}" | tr ' ' '\n' | sort -u >> "${DEP_PR}"
|
|
}
|
|
|
|
function check_diff() {
|
|
set +e
|
|
the_diff=$(diff "${DEP}" "${DEP_PR}")
|
|
set -e
|
|
rm -rf "${DEP_PR}"
|
|
if [[ -n "${the_diff}" ]]; then
|
|
echo "Dependency List Changed Detected: "
|
|
echo "${the_diff}"
|
|
echo "To update the dependency file, run './dev/dependencies.sh --replace'."
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function exit_with_usage() {
|
|
echo "Usage: $0 [--sbt | --mvn] [--replace] [--check] [--module MODULE_VALUE] [--help]"
|
|
exit 1
|
|
}
|
|
|
|
# Parse arguments
|
|
while (( "$#" )); do
|
|
case $1 in
|
|
--sbt)
|
|
SBT_ENABLED="true"
|
|
;;
|
|
--mvn)
|
|
SBT_ENABLED="false"
|
|
;;
|
|
--replace)
|
|
REPLACE="true"
|
|
;;
|
|
--check)
|
|
CHECK="true"
|
|
;;
|
|
--module) # Support for --module parameter
|
|
shift
|
|
MODULE="$1"
|
|
;;
|
|
--help)
|
|
exit_with_usage
|
|
;;
|
|
--*)
|
|
echo "Error: $1 is not supported"
|
|
exit_with_usage
|
|
;;
|
|
*)
|
|
echo "Error: $1 is not supported"
|
|
exit_with_usage
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
case "$MODULE" in
|
|
"spark-2.4")
|
|
MVN_MODULES="client-spark/spark-2"
|
|
SBT_PROJECT="celeborn-client-spark-2"
|
|
;;
|
|
"spark-3"*) # Match all versions starting with "spark-3"
|
|
MVN_MODULES="client-spark/spark-3"
|
|
SBT_PROJECT="celeborn-client-spark-3"
|
|
;;
|
|
"spark-4"*) # Match all versions starting with "spark-4"
|
|
MVN_MODULES="client-spark/spark-3"
|
|
SBT_PROJECT="celeborn-client-spark-4"
|
|
;;
|
|
"flink-1.16")
|
|
MVN_MODULES="client-flink/flink-1.16"
|
|
SBT_PROJECT="celeborn-client-flink-1_16"
|
|
;;
|
|
"flink-1.17")
|
|
MVN_MODULES="client-flink/flink-1.17"
|
|
SBT_PROJECT="celeborn-client-flink-1_17"
|
|
;;
|
|
"flink-1.18")
|
|
MVN_MODULES="client-flink/flink-1.18"
|
|
SBT_PROJECT="celeborn-client-flink-1_18"
|
|
;;
|
|
"flink-1.19")
|
|
MVN_MODULES="client-flink/flink-1.19"
|
|
SBT_PROJECT="celeborn-client-flink-1_19"
|
|
;;
|
|
"flink-1.20")
|
|
MVN_MODULES="client-flink/flink-1.20"
|
|
SBT_PROJECT="celeborn-client-flink-1_20"
|
|
;;
|
|
"flink-2.0")
|
|
MVN_MODULES="client-flink/flink-2.0"
|
|
SBT_PROJECT="celeborn-client-flink-2_0"
|
|
;;
|
|
"flink-2.1")
|
|
MVN_MODULES="client-flink/flink-2.1"
|
|
SBT_PROJECT="celeborn-client-flink-2_1"
|
|
;;
|
|
"mr")
|
|
MVN_MODULES="client-mr/mr"
|
|
SBT_PROJECT="celeborn-client-mr"
|
|
;;
|
|
"tez")
|
|
MVN_MODULES="client-tez/tez"
|
|
SBT_PROJECT="celeborn-client-tez"
|
|
;;
|
|
*)
|
|
MODULE="server"
|
|
MVN_MODULES="worker,master,cli"
|
|
;;
|
|
esac
|
|
|
|
|
|
if [ "$MODULE" = "server" ]; then
|
|
DEP="${PWD}/dev/deps/dependencies-server"
|
|
DEP_PR="${PWD}/dev/deps/dependencies-server.tmp"
|
|
else
|
|
DEP="${PWD}/dev/deps/dependencies-client-$MODULE"
|
|
DEP_PR="${PWD}/dev/deps/dependencies-client-$MODULE.tmp"
|
|
fi
|
|
|
|
rm -rf "${DEP_PR}"
|
|
cat >"${DEP_PR}"<<EOF
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
EOF
|
|
|
|
if [ "$SBT_ENABLED" == "true" ]; then
|
|
if [ "$MODULE" == "server" ]; then
|
|
sbt_build_server_classpath
|
|
else
|
|
sbt_build_client_classpath
|
|
fi
|
|
else
|
|
mvn_build_classpath
|
|
fi
|
|
|
|
if [ "$REPLACE" == "true" ]; then
|
|
rm -rf "${DEP}"
|
|
mv "${DEP_PR}" "${DEP}"
|
|
exit 0
|
|
fi
|
|
|
|
if [ "$CHECK" == "true" ]; then
|
|
check_diff
|
|
fi
|