MCP HubMCP Hub
Вернуться к навыкам

create-multistage-dockerfile

pjt222
Обновлено Yesterday
2 просмотров
17
2
17
Посмотреть на GitHub
Метаaidesign

О программе

Этот навык создает многоэтапные Dockerfile, которые разделяют окружения сборки и выполнения для создания минимальных производственных образов. Он полезен, когда ваши образы слишком велики, содержат ненужные инструменты сборки или требуют оптимизации для ограниченных сред, таких как serverless. Навык охватывает разделение builder/runtime, копирование артефактов и различные базовые образы, включая scratch и distroless.

Быстрая установка

Claude Code

Рекомендуется
Основной
npx skills add pjt222/agent-almanac -a claude-code
Команда плагинаАльтернативный
/plugin add https://github.com/pjt222/agent-almanac
Git клонированиеАльтернативный
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-multistage-dockerfile

Скопируйте и вставьте эту команду в Claude Code для установки этого навыка

Документация

建多階 Dockerfile

建多階 Dockerfile,分建與運境,以最小產像。

用時

  • 產像過大(編譯語 >500MB)
  • 建具(編譯器、dev 標頭)入終像
  • 欲由一 Dockerfile 分生開發與產像
  • 布至限境(邊緣、無服器)

  • 必要:現 Dockerfile 或欲容器化之項目
  • 必要:語與建系(npm、pip、go build、cargo、maven)
  • 可選:運基(slim、alpine、distroless、scratch)
  • 可選:終像尺之限

第一步:分建對運依

建階運階
編譯器gcc、g++、rustc不需
包管npm、pip、cargo或需(解釋語)
dev 標頭-dev不需
源碼全源樹唯編譯之出
試框jest、pytest不需

第二步:構多階建

核心式:於肥像中建,將物複至瘦像。

# ---- Build Stage ----
FROM <build-image> AS builder
WORKDIR /src
COPY <dependency-manifest> .
RUN <install-dependencies>
COPY . .
RUN <build-command>

# ---- Runtime Stage ----
FROM <runtime-image>
COPY --from=builder /src/<artifact> /<dest>
EXPOSE <port>
CMD [<entrypoint>]

第三步:施語專式

Node.js(剪 node_modules)

FROM node:22-bookworm AS builder
WORKDIR /src
COPY package.json package-lock.json ./
RUN npm ci
COPY . .
RUN npm run build && npm prune --omit=dev

FROM node:22-bookworm-slim
RUN groupadd -r app && useradd -r -g app app
WORKDIR /app
COPY --from=builder /src/dist ./dist
COPY --from=builder /src/node_modules ./node_modules
COPY --from=builder /src/package.json .
USER app
EXPOSE 3000
CMD ["node", "dist/index.js"]

Python(虛境複)

FROM python:3.12-bookworm AS builder
WORKDIR /src
RUN python -m venv /opt/venv
ENV PATH="/opt/venv/bin:$PATH"
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
COPY . .

FROM python:3.12-slim-bookworm
COPY --from=builder /opt/venv /opt/venv
ENV PATH="/opt/venv/bin:$PATH"
WORKDIR /app
COPY --from=builder /src .
RUN groupadd -r app && useradd -r -g app app
USER app
EXPOSE 8000
CMD ["python", "app.py"]

Go(靜二進至 scratch)

FROM golang:1.23-bookworm AS builder
WORKDIR /src
COPY go.mod go.sum ./
RUN go mod download
COPY . .
RUN CGO_ENABLED=0 GOOS=linux go build -ldflags="-s -w" -o /server ./cmd/server

FROM scratch
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
COPY --from=builder /server /server
EXPOSE 8080
ENTRYPOINT ["/server"]

Rust(靜 musl 二進)

FROM rust:1.82-bookworm AS builder
RUN apt-get update && apt-get install -y musl-tools && rm -rf /var/lib/apt/lists/*
RUN rustup target add x86_64-unknown-linux-musl
WORKDIR /src
COPY Cargo.toml Cargo.lock ./
RUN mkdir src && echo "fn main() {}" > src/main.rs \
    && cargo build --release --target x86_64-unknown-linux-musl \
    && rm -rf src
COPY . .
RUN touch src/main.rs && cargo build --release --target x86_64-unknown-linux-musl

FROM scratch
COPY --from=builder /src/target/x86_64-unknown-linux-musl/release/myapp /myapp
EXPOSE 8080
ENTRYPOINT ["/myapp"]

得: 終像唯含運與編譯之物。

敗則:COPY --from=builder 路。以 docker build --target builder 調建階。

第四步:擇運基

用案
scratch0 MB靜 Go/Rust 二進
gcr.io/distroless/static~2 MB靜二進 + CA 證
gcr.io/distroless/base~20 MB動二進(libc)
*-slim50-150 MB解釋語
alpine~7 MB需殼訪時

注: Alpine 用 musl libc。部分 Python wheel 與 Node 原模可不行。解釋語宜 -slim(glibc)。

第五步:跨階建參

ARG APP_VERSION=0.0.0

FROM golang:1.23 AS builder
ARG APP_VERSION
RUN go build -ldflags="-X main.version=${APP_VERSION}" -o /server .

FROM gcr.io/distroless/static
COPY --from=builder /server /server
ENTRYPOINT ["/server"]

建以:docker build --build-arg APP_VERSION=1.2.3 .

注: FROM 前之 ARG 為全域。各階須重聲 ARG 以用。

第六步:較像尺

# Build both variants
docker build -t myapp:fat --target builder .
docker build -t myapp:slim .

# Compare sizes
docker images --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}" | grep myapp

得: 產像比建階小 50-90%。

  • docker build 畢諸階
  • 終像不含建具(編譯器、dev 標頭)
  • docker run 由瘦像正行
  • 像尺比單階大減
  • COPY --from=builder 路正
  • 源碼不洩入產像

  • 缺運庫:編譯碼或需共享庫(libclibssl)。瘦像宜徹試。
  • COPY --from 路破:物路須精合。以 docker build --target builderdocker run --rm builder ls /path 調。
  • Alpine musl 問:Node.js 原附加與部分 Python 包於 Alpine 敗。宜用 -slim
  • 全 ARG 範FROM 前之 ARGFROM 行可用。需用之階內重聲。
  • 忘 CA 證scratch 無證。由建者複 /etc/ssl/certs/ca-certificates.crt 或用 distroless。

  • create-dockerfile — 單階通用 Dockerfile
  • create-r-dockerfile — R 專 Dockerfile 用 rocker 像
  • optimize-docker-build-cache — 層緩與 BuildKit 之能
  • setup-compose-stack — 用多階像之 compose 配

GitHub репозиторий

pjt222/agent-almanac
Путь: i18n/wenyan/skills/create-multistage-dockerfile
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Похожие навыки

content-collections

Мета

Этот навык предоставляет проверенную в продакшене настройку для Content Collections — TypeScript-ориентированного инструмента, который преобразует файлы Markdown/MDX в типобезопасные коллекции данных с валидацией Zod. Используйте его при создании блогов, сайтов документации или контентных приложений на Vite + React для обеспечения типобезопасности и автоматической проверки содержимого. Он охватывает всё: от настройки плагина Vite и компиляции MDX до оптимизации развертывания и валидации схем.

Просмотреть навык

polymarket

Мета

Этот навык позволяет разработчикам создавать приложения на платформе прогнозных рынков Polymarket, включая интеграцию с API для торговли и получения рыночных данных. Он также обеспечивает потоковую передачу данных в реальном времени через WebSocket для отслеживания текущих сделок и рыночной активности. Используйте его для реализации торговых стратегий или создания инструментов, обрабатывающих обновления рынка в реальном времени.

Просмотреть навык

creating-opencode-plugins

Мета

Этот навык помогает разработчикам создавать плагины OpenCode, которые подключаются к более чем 25 типам событий, таким как команды, файлы и операции LSP. Он предоставляет структуру плагина, спецификации API событий и шаблоны реализации для модулей на JavaScript/TypeScript. Используйте его, когда вам нужно перехватывать, отслеживать или расширять жизненный цикл ассистента OpenCode AI с помощью пользовательской событийно-ориентированной логики.

Просмотреть навык

sglang

Мета

SGLang — это высокопроизводительный фреймворк для обслуживания больших языковых моделей (LLM), специализирующийся на быстрой структурированной генерации JSON, regex и рабочих процессов агентов с использованием кэширования префиксов RadixAttention. Он обеспечивает значительно более высокую скорость вывода, особенно для задач с повторяющимися префиксами, что делает его идеальным для сложных структурированных результатов и многократных диалогов. Выбирайте SGLang вместо альтернатив, таких как vLLM, когда вам требуется ограниченное декодирование или вы создаете приложения с интенсивным совместным использованием префиксов.

Просмотреть навык