Perf: Optimize Dockerfile with multi-stage build and shallow clone
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 1m58s
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 1m58s
This commit is contained in:
46
Dockerfile
46
Dockerfile
@@ -1,6 +1,7 @@
|
|||||||
FROM node:22-bookworm
|
# Stage 1: Builder
|
||||||
|
FROM node:22-bookworm AS builder
|
||||||
|
|
||||||
# Install system dependencies
|
# Install build dependencies
|
||||||
RUN apt-get update && apt-get install -y \
|
RUN apt-get update && apt-get install -y \
|
||||||
curl \
|
curl \
|
||||||
git \
|
git \
|
||||||
@@ -11,37 +12,54 @@ RUN apt-get update && apt-get install -y \
|
|||||||
unzip \
|
unzip \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Install Bun (required for build scripts)
|
# Install Bun
|
||||||
RUN curl -fsSL https://bun.sh/install | bash
|
RUN curl -fsSL https://bun.sh/install | bash
|
||||||
ENV BUN_INSTALL="/root/.bun"
|
ENV BUN_INSTALL="/root/.bun"
|
||||||
ENV PATH="${BUN_INSTALL}/bin:${PATH}"
|
ENV PATH="${BUN_INSTALL}/bin:${PATH}"
|
||||||
|
|
||||||
# Enable pnpm
|
|
||||||
RUN corepack enable
|
RUN corepack enable
|
||||||
|
|
||||||
WORKDIR /home/node/app
|
WORKDIR /app
|
||||||
|
|
||||||
# Clone the official repository
|
# Clone with depth 1 to save space (removes history)
|
||||||
# We clone into the current directory
|
RUN git clone --depth 1 https://github.com/moltbot/moltbot.git .
|
||||||
RUN git clone https://github.com/moltbot/moltbot.git .
|
|
||||||
|
|
||||||
# Install dependencies
|
# Install dependencies
|
||||||
RUN pnpm install --frozen-lockfile
|
RUN pnpm install --frozen-lockfile
|
||||||
|
|
||||||
# Build application
|
# Build Backend
|
||||||
RUN CLAWDBOT_A2UI_SKIP_MISSING=1 pnpm build
|
RUN CLAWDBOT_A2UI_SKIP_MISSING=1 pnpm build
|
||||||
|
|
||||||
# Build UI
|
# Build UI
|
||||||
# Force pnpm for UI build as per official Dockerfile
|
|
||||||
ENV CLAWDBOT_PREFER_PNPM=1
|
ENV CLAWDBOT_PREFER_PNPM=1
|
||||||
RUN pnpm ui:install
|
RUN pnpm ui:install
|
||||||
RUN pnpm ui:build
|
RUN pnpm ui:build
|
||||||
|
|
||||||
# Fix permissions for the node user
|
# Remove devDependencies to reduce size
|
||||||
RUN chown -R node:node /home/node/app
|
RUN pnpm prune --prod
|
||||||
|
|
||||||
# Security: Run as non-root
|
# Remove .git folder to save space
|
||||||
|
RUN rm -rf .git
|
||||||
|
|
||||||
|
# Stage 2: Runner
|
||||||
|
FROM node:22-bookworm-slim
|
||||||
|
|
||||||
|
WORKDIR /home/node/app
|
||||||
|
|
||||||
|
# Install runtime dependencies (lightweight)
|
||||||
|
# build tools (make, g++) are not needed for runtime
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
python3 \
|
||||||
|
socat \
|
||||||
|
git \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Set user
|
||||||
USER node
|
USER node
|
||||||
|
|
||||||
# Start the application
|
# Copy application from builder
|
||||||
|
# We copy the entire folder as pruned by 'pnpm prune --prod'
|
||||||
|
COPY --from=builder --chown=node:node /app /home/node/app
|
||||||
|
|
||||||
|
# Start
|
||||||
CMD ["node", "dist/index.js"]
|
CMD ["node", "dist/index.js"]
|
||||||
|
|||||||
Reference in New Issue
Block a user