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"]