mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-05-13 05:12:55 -07:00
feat(build): decouple maintainer image into dedicated Dockerfile
This commit is contained in:
@@ -0,0 +1,52 @@
|
|||||||
|
# --- STAGE 1: Base Runtime ---
|
||||||
|
FROM docker.io/library/node:20-slim AS base
|
||||||
|
|
||||||
|
ARG CLI_VERSION_ARG
|
||||||
|
ENV CLI_VERSION=$CLI_VERSION_ARG
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||||
|
python3 \
|
||||||
|
curl \
|
||||||
|
dnsutils \
|
||||||
|
less \
|
||||||
|
jq \
|
||||||
|
ca-certificates \
|
||||||
|
&& apt-get clean \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# --- STAGE 2: Maintainer ---
|
||||||
|
FROM base AS maintainer
|
||||||
|
|
||||||
|
# Install "Maintainer Bloat" - tools needed for development and offloading
|
||||||
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||||
|
make \
|
||||||
|
g++ \
|
||||||
|
gh \
|
||||||
|
git \
|
||||||
|
unzip \
|
||||||
|
rsync \
|
||||||
|
ripgrep \
|
||||||
|
procps \
|
||||||
|
psmisc \
|
||||||
|
lsof \
|
||||||
|
socat \
|
||||||
|
build-essential \
|
||||||
|
libsecret-1-dev \
|
||||||
|
libkrb5-dev \
|
||||||
|
&& apt-get clean \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Install global dev tools
|
||||||
|
RUN npm install -g tsx vitest
|
||||||
|
|
||||||
|
# Set up npm global package folder
|
||||||
|
RUN mkdir -p /usr/local/share/npm-global \
|
||||||
|
&& chown -R node:node /usr/local/share/npm-global
|
||||||
|
ENV NPM_CONFIG_PREFIX=/usr/local/share/npm-global
|
||||||
|
ENV PATH=$PATH:/usr/local/share/npm-global/bin
|
||||||
|
|
||||||
|
# Switch to non-root user node
|
||||||
|
USER node
|
||||||
|
|
||||||
|
# Default entrypoint
|
||||||
|
CMD ["/bin/bash"]
|
||||||
@@ -47,7 +47,7 @@ steps:
|
|||||||
env:
|
env:
|
||||||
- 'GEMINI_SANDBOX=$_CONTAINER_TOOL'
|
- 'GEMINI_SANDBOX=$_CONTAINER_TOOL'
|
||||||
|
|
||||||
# Step 6: Build maintainer container image (Maintainer stage)
|
# Step 6: Build maintainer container image (Dedicated Maintainer Dockerfile)
|
||||||
- name: 'us-west1-docker.pkg.dev/gemini-code-dev/gemini-code-containers/gemini-code-builder'
|
- name: 'us-west1-docker.pkg.dev/gemini-code-dev/gemini-code-containers/gemini-code-builder'
|
||||||
id: 'Build maintainer Docker image'
|
id: 'Build maintainer Docker image'
|
||||||
entrypoint: 'bash'
|
entrypoint: 'bash'
|
||||||
@@ -56,7 +56,7 @@ steps:
|
|||||||
- |-
|
- |-
|
||||||
export TAG=$$(cat /workspace/image_tag.txt)
|
export TAG=$$(cat /workspace/image_tag.txt)
|
||||||
IMAGE_BASE="us-docker.pkg.dev/gemini-code-dev/gemini-cli/maintainer"
|
IMAGE_BASE="us-docker.pkg.dev/gemini-code-dev/gemini-cli/maintainer"
|
||||||
docker build --target maintainer -t "$${IMAGE_BASE}:$${TAG}" .
|
docker build -f .gcp/Dockerfile.maintainer -t "$${IMAGE_BASE}:$${TAG}" .
|
||||||
docker push "$${IMAGE_BASE}:$${TAG}"
|
docker push "$${IMAGE_BASE}:$${TAG}"
|
||||||
env:
|
env:
|
||||||
- 'GEMINI_SANDBOX=$_CONTAINER_TOOL'
|
- 'GEMINI_SANDBOX=$_CONTAINER_TOOL'
|
||||||
|
|||||||
+14
-29
@@ -1,26 +1,21 @@
|
|||||||
# --- STAGE 1: Base Runtime ---
|
FROM docker.io/library/node:20-slim
|
||||||
FROM docker.io/library/node:20-slim AS base
|
|
||||||
|
|
||||||
|
ARG SANDBOX_NAME="gemini-cli-sandbox"
|
||||||
ARG CLI_VERSION_ARG
|
ARG CLI_VERSION_ARG
|
||||||
|
ENV SANDBOX="$SANDBOX_NAME"
|
||||||
ENV CLI_VERSION=$CLI_VERSION_ARG
|
ENV CLI_VERSION=$CLI_VERSION_ARG
|
||||||
|
|
||||||
|
# install minimal set of packages, then clean up
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||||
python3 \
|
python3 \
|
||||||
|
make \
|
||||||
|
g++ \
|
||||||
|
man-db \
|
||||||
curl \
|
curl \
|
||||||
dnsutils \
|
dnsutils \
|
||||||
less \
|
less \
|
||||||
jq \
|
jq \
|
||||||
ca-certificates \
|
bc \
|
||||||
&& apt-get clean \
|
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
# --- STAGE 2: Maintainer (Parent of Sandbox) ---
|
|
||||||
FROM base AS maintainer
|
|
||||||
|
|
||||||
# Install "Maintainer Bloat" - tools needed for development and offloading
|
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
||||||
make \
|
|
||||||
g++ \
|
|
||||||
gh \
|
gh \
|
||||||
git \
|
git \
|
||||||
unzip \
|
unzip \
|
||||||
@@ -30,31 +25,21 @@ RUN apt-get update && apt-get install -y --no-install-recommends \
|
|||||||
psmisc \
|
psmisc \
|
||||||
lsof \
|
lsof \
|
||||||
socat \
|
socat \
|
||||||
build-essential \
|
ca-certificates \
|
||||||
libsecret-1-dev \
|
|
||||||
libkrb5-dev \
|
|
||||||
&& apt-get clean \
|
&& apt-get clean \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Install global dev tools
|
# set up npm global package folder under /usr/local/share
|
||||||
RUN npm install -g tsx vitest
|
# give it to non-root user node, already set up in base image
|
||||||
|
|
||||||
# Set up npm global package folder
|
|
||||||
RUN mkdir -p /usr/local/share/npm-global \
|
RUN mkdir -p /usr/local/share/npm-global \
|
||||||
&& chown -R node:node /usr/local/share/npm-global
|
&& chown -R node:node /usr/local/share/npm-global
|
||||||
ENV NPM_CONFIG_PREFIX=/usr/local/share/npm-global
|
ENV NPM_CONFIG_PREFIX=/usr/local/share/npm-global
|
||||||
ENV PATH=$PATH:/usr/local/share/npm-global/bin
|
ENV PATH=$PATH:/usr/local/share/npm-global/bin
|
||||||
|
|
||||||
# --- STAGE 3: Sandbox (Final CLI Image) ---
|
# switch to non-root user node
|
||||||
FROM maintainer AS sandbox
|
|
||||||
|
|
||||||
ARG SANDBOX_NAME="gemini-cli-sandbox"
|
|
||||||
ENV SANDBOX="$SANDBOX_NAME"
|
|
||||||
|
|
||||||
# Switch to non-root user node
|
|
||||||
USER node
|
USER node
|
||||||
|
|
||||||
# Install gemini-cli and clean up
|
# install gemini-cli and clean up
|
||||||
COPY packages/cli/dist/google-gemini-cli-*.tgz /tmp/gemini-cli.tgz
|
COPY packages/cli/dist/google-gemini-cli-*.tgz /tmp/gemini-cli.tgz
|
||||||
COPY packages/core/dist/google-gemini-cli-core-*.tgz /tmp/gemini-core.tgz
|
COPY packages/core/dist/google-gemini-cli-core-*.tgz /tmp/gemini-core.tgz
|
||||||
RUN npm install -g /tmp/gemini-core.tgz \
|
RUN npm install -g /tmp/gemini-core.tgz \
|
||||||
@@ -64,5 +49,5 @@ RUN npm install -g /tmp/gemini-core.tgz \
|
|||||||
&& npm cache clean --force \
|
&& npm cache clean --force \
|
||||||
&& rm -f /tmp/gemini-{cli,core}.tgz
|
&& rm -f /tmp/gemini-{cli,core}.tgz
|
||||||
|
|
||||||
# Default entrypoint
|
# default entrypoint when none specified
|
||||||
CMD ["gemini"]
|
CMD ["gemini"]
|
||||||
|
|||||||
Reference in New Issue
Block a user