| # |
| # 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. |
| # |
| |
| # Fail if there is an error |
| set -ex |
| |
| SCRIPT_DIR=$(realpath "$(dirname ${0})") |
| echo "Running from ${SCRIPT_DIR}/${0}" |
| |
| APACHE_ARCHIVE_ROOT=http://archive.apache.org/dist |
| HADOOP_VERSION=3.3.1 |
| HADOOP_PACKAGE="hadoop-${HADOOP_VERSION}.tar.gz" |
| HIVE_VERSION=2.3.9 |
| HIVE_PACKAGE="apache-hive-${HIVE_VERSION}-bin.tar.gz" |
| SPARK_VERSION=3.2.3 |
| SPARK_PACKAGE="spark-${SPARK_VERSION}-bin-without-hadoop.tgz" |
| SCALA_VERSION=2.12 |
| LIVY_VERSION="0.8.0-incubating_${SCALA_VERSION}" |
| LIVY_PACKAGE="apache-livy-${LIVY_VERSION}-bin.zip" |
| LOCALLY_BUILT_LIVY_PACKAGE="${SCRIPT_DIR}/../../assembly/target/${LIVY_PACKAGE}" |
| |
| # Download hadoop if needed |
| if [ ! -f "${SCRIPT_DIR}/livy-dev-spark/${HADOOP_PACKAGE}" ]; then |
| curl --fail -L --retry 3 -o "${SCRIPT_DIR}/livy-dev-spark/${HADOOP_PACKAGE}" \ |
| "${APACHE_ARCHIVE_ROOT}/hadoop/common/hadoop-${HADOOP_VERSION}/${HADOOP_PACKAGE}" |
| fi |
| |
| # Download hive if needed |
| if [ ! -f "${SCRIPT_DIR}/livy-dev-spark/${HIVE_PACKAGE}" ]; then |
| curl --fail -L --retry 3 -o "${SCRIPT_DIR}/livy-dev-spark/${HIVE_PACKAGE}" \ |
| "${APACHE_ARCHIVE_ROOT}/hive/hive-${HIVE_VERSION}/${HIVE_PACKAGE}" |
| fi |
| |
| # Download spark if needed |
| if [ ! -f "${SCRIPT_DIR}/livy-dev-spark/${SPARK_PACKAGE}" ]; then |
| curl --fail -L --retry 3 -o "${SCRIPT_DIR}/livy-dev-spark/${SPARK_PACKAGE}" \ |
| "${APACHE_ARCHIVE_ROOT}/spark/spark-${SPARK_VERSION}/${SPARK_PACKAGE}" |
| fi |
| |
| # Check if livy build exists locally |
| if [[ -f "${LOCALLY_BUILT_LIVY_PACKAGE}" && ! -f "${SCRIPT_DIR}/livy-dev-server/${LIVY_PACKAGE}" ]]; then |
| cp ${LOCALLY_BUILT_LIVY_PACKAGE} "${SCRIPT_DIR}/livy-dev-server/${LIVY_PACKAGE}" |
| fi |
| |
| # Download livy if needed |
| if [ ! -f "${SCRIPT_DIR}/livy-dev-server/${LIVY_PACKAGE}" ]; then |
| curl --fail -L --retry 3 -o "${SCRIPT_DIR}/livy-dev-server/${LIVY_PACKAGE}" \ |
| "${APACHE_ARCHIVE_ROOT}/incubator/livy/${LIVY_VERSION}/${LIVY_PACKAGE}" |
| fi |
| |
| |
| docker build -t livy-dev-base "${SCRIPT_DIR}/livy-dev-base/" |
| docker build -t livy-dev-spark "${SCRIPT_DIR}/livy-dev-spark/" --build-arg HADOOP_VERSION=${HADOOP_VERSION} --build-arg SPARK_VERSION=${SPARK_VERSION} |
| docker build -t livy-dev-server "${SCRIPT_DIR}/livy-dev-server/" --build-arg LIVY_VERSION=${LIVY_VERSION} |