### What changes were proposed in this pull request? Dockerfile should support copying CLI jars. ### Why are the changes needed? CLI jars are generated from `make-distribution.sh`. Therefore, Dockerfile could copy CLI jars to `/opt/celeborn/` directory. ### Does this PR introduce _any_ user-facing change? No. ### How was this patch tested? No. Closes #2823 from SteNicholas/CELEBORN-1659. Authored-by: SteNicholas <programgeek@163.com> Signed-off-by: mingji <fengmingxiao.fmx@alibaba-inc.com>
57 lines
2.0 KiB
Docker
57 lines
2.0 KiB
Docker
#
|
|
# 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.
|
|
#
|
|
|
|
ARG java_image_tag=8-jdk-focal
|
|
FROM eclipse-temurin:${java_image_tag}
|
|
|
|
ARG celeborn_uid=10006
|
|
ARG celeborn_gid=10006
|
|
|
|
ENV CELEBORN_HOME=/opt/celeborn
|
|
ENV CELEBORN_PREFER_JEMALLOC=true
|
|
ENV PATH=${PATH}:/opt/busybox:${CELEBORN_HOME}/sbin:${CELEBORN_HOME}/bin
|
|
|
|
RUN set -ex && \
|
|
apt-get update && \
|
|
apt-get install -y bash tini busybox bind9-utils telnet net-tools procps krb5-user dnsutils libjemalloc-dev && \
|
|
ln -snf /bin/bash /bin/sh && \
|
|
rm -rf /var/cache/apt/* && \
|
|
mkdir /opt/busybox && \
|
|
busybox --install /opt/busybox && \
|
|
groupadd --gid=${celeborn_gid} celeborn && \
|
|
useradd --uid=${celeborn_uid} --gid=${celeborn_gid} celeborn -d /home/celeborn -m && \
|
|
mkdir -p ${CELEBORN_HOME}
|
|
|
|
COPY bin /opt/celeborn/bin
|
|
COPY sbin /opt/celeborn/sbin
|
|
COPY conf /opt/celeborn/conf
|
|
COPY jars /opt/celeborn/jars
|
|
COPY master-jars /opt/celeborn/master-jars
|
|
COPY worker-jars /opt/celeborn/worker-jars
|
|
COPY cli-jars /opt/celeborn/cli-jars
|
|
COPY RELEASE /opt/celeborn/RELEASE
|
|
|
|
RUN chown -R celeborn:celeborn ${CELEBORN_HOME} && \
|
|
chmod -R ug+rw ${CELEBORN_HOME} && \
|
|
chmod a+x ${CELEBORN_HOME}/bin/* && \
|
|
chmod a+x ${CELEBORN_HOME}/sbin/*
|
|
|
|
USER celeborn
|
|
WORKDIR /opt/celeborn
|
|
|
|
ENTRYPOINT ["/usr/bin/tini", "--"]
|