From f915ed63c224ac071f9b340a451c0b352b8f8374 Mon Sep 17 00:00:00 2001 From: Viktor Karamanis <31246197+vkaramanis@users.noreply.github.com> Date: Wed, 9 Oct 2024 03:49:56 +0200 Subject: [PATCH] build: Dockerfile-alpine-python and Makefile build (#3271) Signed-off-by: Viktor Karamanis Co-authored-by: Vrump Co-authored-by: Rory <16801068+Rory-Z@users.noreply.github.com> --- .github/workflows/build_packages.yaml | 1 + Makefile | 1 + deploy/docker/Dockerfile-alpine-python | 54 ++++++++++++++++++++++++++ 3 files changed, 56 insertions(+) create mode 100644 deploy/docker/Dockerfile-alpine-python diff --git a/.github/workflows/build_packages.yaml b/.github/workflows/build_packages.yaml index 63669db1a8..8f45fadd99 100644 --- a/.github/workflows/build_packages.yaml +++ b/.github/workflows/build_packages.yaml @@ -130,6 +130,7 @@ jobs: suffix: - "" - "-alpine" + - "-alpine-python" - "-dev" - "-slim" - "-slim-python" diff --git a/Makefile b/Makefile index 05017dec09..a17f947e4a 100644 --- a/Makefile +++ b/Makefile @@ -156,6 +156,7 @@ docker: docker buildx build --no-cache --platform=linux/amd64 -t $(TARGET):$(VERSION)-slim -f deploy/docker/Dockerfile-slim . --load docker buildx build --no-cache --platform=linux/amd64 -t $(TARGET):$(VERSION)-full -f deploy/docker/Dockerfile-full . --load docker buildx build --no-cache --platform=linux/amd64 -t $(TARGET):$(VERSION)-dev -f deploy/docker/Dockerfile-dev . --load + docker buildx build --no-cache --platform=linux/amd64 -t $(TARGET):$(VERSION)-alpine-python -f deploy/docker/Dockerfile-alpine-python . --load PLUGINS := sinks/influx \ sinks/influx2 \ diff --git a/deploy/docker/Dockerfile-alpine-python b/deploy/docker/Dockerfile-alpine-python new file mode 100644 index 0000000000..936cebecfb --- /dev/null +++ b/deploy/docker/Dockerfile-alpine-python @@ -0,0 +1,54 @@ +# Copyright 2021-2023 EMQ Technologies Co., Ltd. +# +# Licensed 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 GO_VERSION=1.23.1 +FROM ghcr.io/lf-edge/ekuiper/base:$GO_VERSION-alpine AS builder + +COPY . /go/kuiper + +WORKDIR /go/kuiper + +RUN make build_with_edgex + +FROM python:3.12-alpine + +# Set environment vars +ENV MAINTAINER="emqx.io" \ + KUIPER_HOME="/kuiper" \ + KUIPER__BASIC__CONSOLELOG=true + +# These vars are not persisted in the final image layer +ARG KUIPER_USER="kuiper" +ARG KUIPER_USER_ID="1001" + +WORKDIR ${KUIPER_HOME} + +# Set appropriate ownership to allow binary full access to KUIPER_HOME dir +RUN adduser -DH -s /sbin/nologin -u ${KUIPER_USER_ID} ${KUIPER_USER} && \ + chown -Rh ${KUIPER_USER}:${KUIPER_USER} ${KUIPER_HOME} && \ + mkdir -p /usr/local/taos && \ + chown -Rh ${KUIPER_USER}:${KUIPER_USER} /usr/local/taos + +# Run the kuiper process under the kuiper user +USER ${KUIPER_USER} + +COPY --chown=${KUIPER_USER}:${KUIPER_USER} ./deploy/docker/docker-entrypoint.sh /usr/bin/docker-entrypoint.sh +COPY --chown=${KUIPER_USER}:${KUIPER_USER} --from=builder /go/kuiper/_build/kuiper-* /kuiper/ + +VOLUME ["${KUIPER_HOME}/etc", "${KUIPER_HOME}/data", "${KUIPER_HOME}/plugins", "${KUIPER_HOME}/log"] +EXPOSE 9081 20498 + +ENTRYPOINT ["/usr/bin/docker-entrypoint.sh"] + +CMD ["./bin/kuiperd"]