Kyuubi Docker 镜像构建

本文参考 Kyuubi 官方文档 https://kyuubi.apache.org/docs/r1.5.2-incubating/deployment/kyuubi_on_kubernetes.html#build-kyuubi-docker-image

一、环境

组件版本备注
kyuubi1.5.2
Spark3.3.0基础镜像

二、Docker 镜像构建

#####################################################################################################################################
# 1. 环境变量
#####################################################################################################################################

#自定义目录,根据实际情况进行更改
BASE_DIR=/opt/soft/lakehouse/kyuubi
USER_HOME=/home/luke
#镜像仓库地址
HARBOR_PATH=core.harbor.apps.g66666.hk.my-demo.tech/lakehouse
#版本变量
KYUUBI_VERSION=1.5.2
KYUUBI_IMAGE_VERSION=v1.5.2
SPARK_VERSION=3.3.0
SPARK_BASE_IMAGES=${HARBOR_PATH}/spark-volcano:${SPARK_VERSION}

#####################################################################################################################################
# 2. 下载二进制安装包
#####################################################################################################################################
cd ${BASE_DIR}
# 下载源码包
wget https://dlcdn.apache.org/incubator/kyuubi/kyuubi-${KYUUBI_VERSION}-incubating/apache-kyuubi-${KYUUBI_VERSION}-incubating-bin.tgz
 # 解压
tar -zxf apache-kyuubi-${KYUUBI_VERSION}-incubating-bin.tgz

#####################################################################################################################################
# 3. 编写Dockerfile
#####################################################################################################################################

cd ${BASE_DIR}/apache-kyuubi-${KYUUBI_VERSION}-incubating-bin/docker


cat << EOF | tee Dockerfile
# Usage:
#   1. use ./build/dist to make binary distributions of Kyuubi or download a release
#   2. Untar it and run the docker command below
#      docker build -f docker/Dockerfile -t repository/kyuubi:tagname .
#   Options:
#     -f this docker file
#     -t the target repo and tag name
#     more options can be found with -h

ARG BASE_IMAGE=openjdk:8-jre-slim
ARG spark_provided="spark_builtin"

FROM \${BASE_IMAGE} as builder_spark_provided
ONBUILD ARG spark_home_in_docker
ONBUILD ENV SPARK_HOME \${spark_home_in_docker}

FROM \${BASE_IMAGE} as builder_spark_builtin

ONBUILD ENV SPARK_HOME /opt/spark
ONBUILD RUN mkdir -p  \${SPARK_HOME}
ONBUILD COPY spark-binary \${SPARK_HOME}

FROM builder_\${spark_provided}

ARG kyuubi_uid=10009
USER root

ENV KYUUBI_HOME /opt/kyuubi
ENV KYUUBI_LOG_DIR \${KYUUBI_HOME}/logs
ENV KYUUBI_PID_DIR \${KYUUBI_HOME}/pid
ENV KYUUBI_WORK_DIR_ROOT \${KYUUBI_HOME}/work

RUN set -ex && \
    sed -i 's/http:\/\/deb.\(.*\)/https:\/\/deb.\1/g' /etc/apt/sources.list && \
    apt-get update && \
    apt install -y bash tini libc6 libpam-modules krb5-user libnss3 procps && \
    useradd -u \${kyuubi_uid} -g root kyuubi && \
    mkdir -p \${KYUUBI_HOME} \${KYUUBI_LOG_DIR} \${KYUUBI_PID_DIR} \${KYUUBI_WORK_DIR_ROOT} && \
    chmod ug+rw -R \${KYUUBI_HOME} && \
    chmod a+rwx -R \${KYUUBI_WORK_DIR_ROOT} && \
    rm -rf /var/cache/apt/*

COPY bin \${KYUUBI_HOME}/bin
COPY jars \${KYUUBI_HOME}/jars
COPY externals/engines/spark \${KYUUBI_HOME}/externals/engines/spark

WORKDIR \${KYUUBI_HOME}

CMD [ "./bin/kyuubi", "run" ]

USER \${kyuubi_uid}
EOF

#####################################################################################################################################
# 4. 构建Docker 镜像
#####################################################################################################################################

cd ${BASE_DIR}/apache-kyuubi-${KYUUBI_VERSION}-incubating-bin/docker

sudo ../bin/docker-image-tool.sh \
-f Dockerfile \
-t ${KYUUBI_IMAGE_VERSION} \
-S /opt/spark -b BASE_IMAGE=${SPARK_BASE_IMAGES} build

sudo docker tag kyuubi:${KYUUBI_IMAGE_VERSION} ${HARBOR_PATH}/lakehouse/kyuubi:${KYUUBI_IMAGE_VERSION}
sudo docker push ${HARBOR_PATH}/lakehouse/kyuubi:${KYUUBI_IMAGE_VERSION}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值