CloudBender/Dockerfile

92 lines
2.4 KiB
Docker
Raw Normal View History

2024-11-27 17:13:34 +00:00
ARG RUNTIME_VERSION="3.12"
ARG DISTRO_VERSION="3.20"
2021-09-23 17:27:06 +00:00
FROM python:${RUNTIME_VERSION}-alpine${DISTRO_VERSION} AS builder
2024-11-27 17:13:34 +00:00
ARG RUNTIME_VERSION="3.12"
2021-09-23 17:27:06 +00:00
RUN apk add --no-cache \
autoconf \
automake \
build-base \
cmake \
curl \
make \
libc6-compat \
gcc \
linux-headers \
libffi-dev \
openssl-dev \
git
2021-09-23 17:27:06 +00:00
ENV VIRTUAL_ENV=/venv
RUN python -m venv $VIRTUAL_ENV
ENV PATH="$VIRTUAL_ENV/bin:$PATH"
# Install CloudBender
WORKDIR /app
COPY . /app
RUN pip install . --disable-pip-version-check
# Install matching Pulumi binaries
RUN curl -fsSL https://get.pulumi.com/ | sh -s -- --version $(pip show pulumi --disable-pip-version-check | grep Version: | awk '{print $2}')
2021-09-23 17:27:06 +00:00
# minimal pulumi
2022-07-15 12:35:27 +00:00
RUN cd /root/.pulumi/bin && rm -f *dotnet *yaml *go *java && strip pulumi* || true
2021-09-23 17:27:06 +00:00
# Remove AWS keys from docstring to prevent trivy alerts later
2023-10-27 11:09:07 +00:00
RUN sed -i -e 's/AKIA.*//' /venv/lib/python${RUNTIME_VERSION}/site-packages/pulumi_aws/lightsail/bucket_access_key.py
2021-09-23 17:27:06 +00:00
# Now build the final runtime, incl. running rootless containers
2021-09-23 17:27:06 +00:00
FROM python:${RUNTIME_VERSION}-alpine${DISTRO_VERSION}
ARG USER=cloudbender
#cd /etc/apk/keys && \
#echo "@testing http://dl-cdn.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories && \
#cfssl@testing \
RUN apk upgrade -U --available --no-cache && \
apk add --no-cache \
2021-09-23 17:27:06 +00:00
libstdc++ \
libc6-compat \
ca-certificates \
2022-06-22 13:08:45 +00:00
aws-cli \
fuse-overlayfs \
podman \
buildah \
strace
2021-09-23 17:27:06 +00:00
COPY --from=builder /venv /venv
COPY --from=builder /root/.pulumi/bin /usr/local/bin
# Dont run as root by default
RUN addgroup $USER && adduser $USER -G $USER -D && \
mkdir -p /home/$USER/.local/share/containers && \
chown $USER:$USER -R /home/$USER
# Rootless podman
2022-07-15 12:35:27 +00:00
RUN mkdir -p /home/$USER/.config/containers
ADD --chown=$USER:$USER conf/containers.conf conf/registries.conf conf/storage.conf /home/$USER/.config/containers
RUN echo -e "$USER:1:999\n$USER:1001:64535" > /etc/subuid && \
echo -e "$USER:1:999\n$USER:1001:64535" > /etc/subgid && \
2022-07-15 12:35:27 +00:00
cd /usr/bin && ln -s podman docker && \
chown $USER:$USER -R /home/$USER
2021-09-23 17:27:06 +00:00
WORKDIR /workspace
ENV _CONTAINERS_USERNS_CONFIGURED=""
ENV BUILDAH_ISOLATION=chroot
2021-09-23 17:27:06 +00:00
ENV VIRTUAL_ENV=/venv
ENV PATH="$VIRTUAL_ENV/bin:$PATH"
ENV PULUMI_SKIP_UPDATE_CHECK=true
2021-09-23 17:27:06 +00:00
USER $USER
# Allow container layers to be stored in PVCs
VOLUME /home/$USER/.local/share/containers
2021-09-23 17:27:06 +00:00
CMD ["cloudbender"]