1
This commit is contained in:
parent
4e79d98c78
commit
d099e8395c
6 changed files with 226 additions and 60 deletions
48
Dockerfile
48
Dockerfile
|
@ -16,14 +16,15 @@ RUN --mount=type=tmpfs,target=/var/lib/apt/lists \
|
|||
RUN ARCH=$(dpkg --print-architecture) && curl --fail --silent --parallel --remote-name-all \
|
||||
"https://download.docker.com/linux/debian/dists/bookworm/pool/stable/$ARCH/containerd.io_1.7.27-1_$ARCH.deb" \
|
||||
"https://download.docker.com/linux/debian/dists/bookworm/pool/stable/$ARCH/docker-ce-cli_28.1.1-1~debian.12~bookworm_$ARCH.deb" \
|
||||
"https://download.docker.com/linux/debian/dists/bookworm/pool/stable/$ARCH/docker-buildx-plugin_0.20.0-1~debian.12~bookworm_$ARCH.deb" \
|
||||
"https://download.docker.com/linux/debian/dists/bookworm/pool/stable/$ARCH/docker-ce_28.1.1-1~debian.12~bookworm_$ARCH.deb" \
|
||||
"https://download.docker.com/linux/debian/dists/bookworm/pool/stable/$ARCH/docker-ce-rootless-extras_28.1.1-1~debian.12~bookworm_$ARCH.deb"
|
||||
|
||||
##
|
||||
## Final stage
|
||||
## Docker Daemon
|
||||
##
|
||||
|
||||
FROM docker.io/library/debian:12.11-slim@sha256:e5865e6858dacc255bead044a7f2d0ad8c362433cfaa5acefb670c1edf54dfef
|
||||
FROM docker.io/library/debian:12.11-slim@sha256:e5865e6858dacc255bead044a7f2d0ad8c362433cfaa5acefb670c1edf54dfef AS dockerd
|
||||
SHELL ["/bin/bash", "-u", "-e", "-o", "pipefail", "-c"]
|
||||
RUN --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
||||
--mount=type=tmpfs,target=/var/log \
|
||||
|
@ -36,7 +37,7 @@ RUN --mount=type=bind,from=download,source=/tmp/docker,target=/tmp/docker \
|
|||
--mount=type=tmpfs,target=/var/log \
|
||||
--mount=type=tmpfs,target=/var/cache \
|
||||
apt-get -qq update && \
|
||||
apt-get -qq install --yes --no-install-recommends /tmp/docker/*.deb && \
|
||||
apt-get -qq install --yes --no-install-recommends /tmp/docker/containerd*.deb /tmp/docker/docker-ce*.deb && \
|
||||
rm -rf /etc/*- /var/lib/dpkg/*-old /var/lib/dpkg/status
|
||||
|
||||
RUN useradd dockerd --uid 1000 --home-dir /home/docker --create-home && rm /etc/*- /home/docker/.* && \
|
||||
|
@ -45,3 +46,44 @@ RUN useradd dockerd --uid 1000 --home-dir /home/docker --create-home && rm /etc/
|
|||
COPY --chmod=555 entrypoint.sh /usr/bin/entrypoint.sh
|
||||
ENTRYPOINT ["/usr/bin/entrypoint.sh"]
|
||||
USER 1000
|
||||
|
||||
##
|
||||
## Docker CLI
|
||||
##
|
||||
|
||||
FROM docker.io/library/debian:12.11-slim@sha256:e5865e6858dacc255bead044a7f2d0ad8c362433cfaa5acefb670c1edf54dfef AS cli-base
|
||||
SHELL ["/bin/bash", "-u", "-e", "-o", "pipefail", "-c"]
|
||||
RUN --mount=type=bind,from=download,source=/tmp/docker,target=/tmp/docker \
|
||||
--mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
||||
apt-get -qq update && \
|
||||
apt-get -qq install --yes --no-install-recommends /tmp/docker/docker-buildx-plugin* /tmp/docker/docker-ce-cli*.deb && \
|
||||
rm -rf /etc/*- /var/lib/dpkg/*-old /var/lib/dpkg/status /var/cache/* /var/log/*
|
||||
ENV DOCKER_HOST=tcp://dockerd:2375
|
||||
|
||||
FROM cli-base AS cli-base-az
|
||||
RUN --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
||||
apt-get -qq update && \
|
||||
apt-get -qq install --yes --no-install-recommends python3 pip && \
|
||||
pip install azure-cli==2.66.0 --root-user-action=ignore --no-cache-dir --break-system-packages && \
|
||||
apt-get -qq purge pip && \
|
||||
rm -rf /etc/*- /var/lib/dpkg/*-old /var/lib/dpkg/status /var/cache/* /var/log/*
|
||||
|
||||
FROM cli-base AS cli
|
||||
USER 1000:1000
|
||||
|
||||
FROM cli-base AS cli-git
|
||||
RUN --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
||||
apt-get -qq update && \
|
||||
apt-get -qq install --yes --no-install-recommends git && \
|
||||
rm -rf /etc/*- /var/lib/dpkg/*-old /var/lib/dpkg/status /var/cache/* /var/log/*
|
||||
USER 1000:1000
|
||||
|
||||
FROM cli-base-az AS cli-az
|
||||
USER 1000:1000
|
||||
|
||||
FROM cli-base-az AS cli-az-git
|
||||
RUN --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
||||
apt-get -qq update && \
|
||||
apt-get -qq install --yes --no-install-recommends git && \
|
||||
rm -rf /etc/*- /var/lib/dpkg/*-old /var/lib/dpkg/status /var/cache/* /var/log/*
|
||||
USER 1000:1000
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue