| # |
| # 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-noble |
| 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", "--"] |