2017-08-04 10:40:52 -07:00
|
|
|
#!/usr/bin/env bash
|
2015-04-24 13:05:18 -07:00
|
|
|
|
|
|
|
# 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 -e # exit on error
|
|
|
|
|
|
|
|
cd "$(dirname "$0")" # connect to root
|
|
|
|
|
2020-01-13 10:40:29 +05:30
|
|
|
DOCKER_DIR=dev-support/docker
|
|
|
|
DOCKER_FILE="${DOCKER_DIR}/Dockerfile"
|
|
|
|
|
|
|
|
CPU_ARCH=$(echo "$MACHTYPE" | cut -d- -f1)
|
|
|
|
if [ "$CPU_ARCH" = "aarch64" ]; then
|
|
|
|
DOCKER_FILE="${DOCKER_DIR}/Dockerfile_aarch64"
|
|
|
|
fi
|
|
|
|
|
|
|
|
docker build -t hadoop-build -f $DOCKER_FILE $DOCKER_DIR
|
2015-04-24 13:05:18 -07:00
|
|
|
|
2018-11-20 23:59:08 +09:00
|
|
|
USER_NAME=${SUDO_USER:=$USER}
|
|
|
|
USER_ID=$(id -u "${USER_NAME}")
|
|
|
|
|
|
|
|
if [ "$(uname -s)" = "Darwin" ]; then
|
|
|
|
GROUP_ID=100
|
|
|
|
fi
|
|
|
|
|
2018-02-12 21:07:15 -08:00
|
|
|
if [ "$(uname -s)" = "Linux" ]; then
|
2015-04-24 13:05:18 -07:00
|
|
|
GROUP_ID=$(id -g "${USER_NAME}")
|
2018-02-12 21:07:15 -08:00
|
|
|
# man docker-run
|
|
|
|
# When using SELinux, mounted directories may not be accessible
|
|
|
|
# to the container. To work around this, with Docker prior to 1.7
|
|
|
|
# one needs to run the "chcon -Rt svirt_sandbox_file_t" command on
|
|
|
|
# the directories. With Docker 1.7 and later the z mount option
|
|
|
|
# does this automatically.
|
|
|
|
if command -v selinuxenabled >/dev/null && selinuxenabled; then
|
|
|
|
DCKR_VER=$(docker -v|
|
|
|
|
awk '$1 == "Docker" && $2 == "version" {split($3,ver,".");print ver[1]"."ver[2]}')
|
|
|
|
DCKR_MAJ=${DCKR_VER%.*}
|
|
|
|
DCKR_MIN=${DCKR_VER#*.}
|
|
|
|
if [ "${DCKR_MAJ}" -eq 1 ] && [ "${DCKR_MIN}" -ge 7 ] ||
|
|
|
|
[ "${DCKR_MAJ}" -gt 1 ]; then
|
|
|
|
V_OPTS=:z
|
|
|
|
else
|
|
|
|
for d in "${PWD}" "${HOME}/.m2"; do
|
|
|
|
ctx=$(stat --printf='%C' "$d"|cut -d':' -f3)
|
|
|
|
if [ "$ctx" != svirt_sandbox_file_t ] && [ "$ctx" != container_file_t ]; then
|
|
|
|
printf 'INFO: SELinux is enabled.\n'
|
|
|
|
printf '\tMounted %s may not be accessible to the container.\n' "$d"
|
|
|
|
printf 'INFO: If so, on the host, run the following command:\n'
|
|
|
|
printf '\t# chcon -Rt svirt_sandbox_file_t %s\n' "$d"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
fi
|
2015-04-24 13:05:18 -07:00
|
|
|
fi
|
|
|
|
|
2017-03-04 11:00:03 -08:00
|
|
|
docker build -t "hadoop-build-${USER_ID}" - <<UserSpecificDocker
|
2015-04-24 13:05:18 -07:00
|
|
|
FROM hadoop-build
|
2019-04-10 08:48:11 -07:00
|
|
|
RUN rm -f /var/log/faillog /var/log/lastlog
|
2015-04-24 13:05:18 -07:00
|
|
|
RUN groupadd --non-unique -g ${GROUP_ID} ${USER_NAME}
|
|
|
|
RUN useradd -g ${GROUP_ID} -u ${USER_ID} -k /root -m ${USER_NAME}
|
2018-11-13 13:57:07 +09:00
|
|
|
RUN echo "${USER_NAME} ALL=NOPASSWD: ALL" > "/etc/sudoers.d/hadoop-build-${USER_ID}"
|
2015-04-24 13:05:18 -07:00
|
|
|
ENV HOME /home/${USER_NAME}
|
2017-07-19 17:51:14 -07:00
|
|
|
|
2015-04-24 13:05:18 -07:00
|
|
|
UserSpecificDocker
|
|
|
|
|
2018-06-14 14:14:24 -07:00
|
|
|
#If this env varible is empty, docker will be started
|
|
|
|
# in non interactive mode
|
|
|
|
DOCKER_INTERACTIVE_RUN=${DOCKER_INTERACTIVE_RUN-"-i -t"}
|
|
|
|
|
2015-04-24 13:05:18 -07:00
|
|
|
# By mapping the .m2 directory you can do an mvn install from
|
|
|
|
# within the container and use the result on your normal
|
|
|
|
# system. And this also is a significant speedup in subsequent
|
|
|
|
# builds because the dependencies are downloaded only once.
|
2018-06-14 14:14:24 -07:00
|
|
|
docker run --rm=true $DOCKER_INTERACTIVE_RUN \
|
2018-02-12 21:07:15 -08:00
|
|
|
-v "${PWD}:/home/${USER_NAME}/hadoop${V_OPTS:-}" \
|
2015-04-24 13:05:18 -07:00
|
|
|
-w "/home/${USER_NAME}/hadoop" \
|
2018-02-12 21:07:15 -08:00
|
|
|
-v "${HOME}/.m2:/home/${USER_NAME}/.m2${V_OPTS:-}" \
|
2020-01-13 10:40:29 +05:30
|
|
|
-v "${HOME}/.gnupg:/home/${USER_NAME}/.gnupg${V_OPTS:-}" \
|
2015-04-24 13:05:18 -07:00
|
|
|
-u "${USER_NAME}" \
|
2018-06-14 14:14:24 -07:00
|
|
|
"hadoop-build-${USER_ID}" "$@"
|