celeborn/docker/Dockerfile
Jun He ada12a2c0e
[CELEBORN-900] Prefer to use jemalloc for memory allocation
### What changes were proposed in this pull request?

Only the Dockfile needs to change in this pr.

### Why are the changes needed?

When deploying celeborn for flink on kubernetes, Introducing jemalloc can improve pod memory usage.

### Does this PR introduce _any_ user-facing change?
None

### How was this patch tested?
Maybe starting a production job to test the memory usage improvement is needed.

Closes #1824 from mddxhj/feature/introduce_jemalloc.

Authored-by: Jun He <xuehaijuxian@gmail.com>
Signed-off-by: Cheng Pan <chengpan@apache.org>
2023-09-08 19:49:24 +08:00

54 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 PATH=/opt/java/openjdk/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/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 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
ENTRYPOINT ["/usr/bin/tini", "--"]