Zurück zu Fähigkeiten

create-dockerfile

pjt222
Aktualisiert Yesterday
1 Ansichten
17
2
17
Auf GitHub ansehen
Metageneral

Über

Diese Claude Skill erstellt produktionsreife Dockerfiles für Node.js-, Python-, Go-, Rust- und Java-Projekte. Sie übernimmt die Auswahl des Basis-Images, die Installation von Abhängigkeiten, Benutzerberechtigungen sowie die Konfiguration von COPY-Mustern, ENTRYPOINT/CMD und .dockerignore. Nutzen Sie sie, wenn Sie eine Anwendung erstmals containerisieren, eine Cloud-Bereitstellung vorbereiten oder wenn Ihrem Projekt ein Dockerfile fehlt.

Schnellinstallation

Claude Code

Empfohlen
Primär
npx skills add pjt222/agent-almanac -a claude-code
Plugin-BefehlAlternativ
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativ
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-dockerfile

Kopieren Sie diesen Befehl und fügen Sie ihn in Claude Code ein, um diese Fähigkeit zu installieren

Dokumentation


name: create-dockerfile description: > Node.js、Python、Go、Rust、Javaプロジェクト用の汎用Dockerfileを作成する。ベースイメージの選択、 依存関係のインストール、ユーザー権限、COPYパターン、ENTRYPOINT vs CMD、および.dockerignoreを カバーする。アプリケーションを初めてコンテナ化する場合、一貫したビルド/ランタイム環境の構築、 クラウドデプロイやDocker Compose向けアプリの準備、またはプロジェクトにDockerfileが存在しない 場合に使用する。 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: basic language: Docker tags: docker, dockerfile, node, python, go, rust, java, container locale: ja source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16

Dockerfileの作成

汎用アプリケーションプロジェクト用の本番対応Dockerfileを作成する。

使用タイミング

  • Node.js、Python、Go、Rust、またはJavaアプリケーションのコンテナ化
  • 一貫したビルド/ランタイム環境の構築
  • クラウドデプロイまたはDocker Compose向けアプリケーションの準備
  • プロジェクトにDockerfileが存在しない場合

入力

  • 必須: プロジェクト言語とエントリポイント(例: npm startpython app.py
  • 必須: 依存関係マニフェスト(package.json、requirements.txt、go.mod、Cargo.toml、pom.xml)
  • 任意: 対象環境(開発または本番)
  • 任意: 公開ポート

手順

ステップ1: ベースイメージの選択

言語開発イメージ本番イメージサイズ
Node.jsnode:22-bookwormnode:22-bookworm-slim約200MB
Pythonpython:3.12-bookwormpython:3.12-slim-bookworm約150MB
Gogolang:1.23-bookwormgcr.io/distroless/static約2MB
Rustrust:1.82-bookwormdebian:bookworm-slim約80MB
Javaeclipse-temurin:21-jdkeclipse-temurin:21-jre約200MB

期待結果: 本番イメージにはslim/distrolessバリアントを選択する。

ステップ2: Dockerfileの作成(言語別)

Node.js

FROM node:22-bookworm-slim

RUN groupadd -r appuser && useradd -r -g appuser -m appuser

WORKDIR /app

COPY package.json package-lock.json ./
RUN npm ci --omit=dev

COPY . .

USER appuser
EXPOSE 3000
CMD ["node", "src/index.js"]

Python

FROM python:3.12-slim-bookworm

RUN groupadd -r appuser && useradd -r -g appuser -m appuser

WORKDIR /app

COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt

COPY . .

USER appuser
EXPOSE 8000
CMD ["python", "app.py"]

Go

FROM golang:1.23-bookworm AS builder

WORKDIR /src
COPY go.mod go.sum ./
RUN go mod download
COPY . .
RUN CGO_ENABLED=0 go build -o /app/server ./cmd/server

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

Rust

FROM rust:1.82-bookworm AS builder

WORKDIR /src
COPY Cargo.toml Cargo.lock ./
RUN mkdir src && echo "fn main() {}" > src/main.rs && cargo build --release && rm -rf src

COPY . .
RUN touch src/main.rs && cargo build --release

FROM debian:bookworm-slim
RUN apt-get update && apt-get install -y ca-certificates && rm -rf /var/lib/apt/lists/*
COPY --from=builder /src/target/release/myapp /usr/local/bin/myapp
EXPOSE 8080
ENTRYPOINT ["myapp"]

Java (Maven)

FROM eclipse-temurin:21-jdk AS builder

WORKDIR /src
COPY pom.xml .
RUN mvn dependency:go-offline -B
COPY src ./src
RUN mvn package -DskipTests

FROM eclipse-temurin:21-jre
COPY --from=builder /src/target/*.jar /app/app.jar
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "/app/app.jar"]

期待結果: docker build -t myapp .がエラーなく完了する。

失敗時: ベースイメージの利用可能性と依存関係インストールコマンドを確認する。

ステップ3: ENTRYPOINT vs CMD

ディレクティブ用途オーバーライド
ENTRYPOINT固定の実行ファイル--entrypointでオーバーライド
CMDデフォルト引数末尾の引数でオーバーライド
両方ENTRYPOINT + CMDによるデフォルト引数引数はCMDのみオーバーライド

単一目的のコンパイル済みバイナリにはENTRYPOINTを使用する。docker run myapp bashの可能性があるインタープリタ言語にはCMDを使用する。

ステップ4: .dockerignoreの作成

.git
.gitignore
node_modules
__pycache__
*.pyc
target/
.env
.env.*
*.md
!README.md
.vscode
.idea
Dockerfile
docker-compose*.yml

期待結果: ビルドコンテキストが開発成果物を除外する。

ステップ5: 非rootユーザーの追加

本番環境では常に非rootで実行する:

RUN groupadd -r appuser && useradd -r -g appuser -m appuser
USER appuser

distrolessイメージの場合、組み込みのnonrootユーザーを使用する:

FROM gcr.io/distroless/static:nonroot
USER nonroot

ステップ6: ビルドと検証

docker build -t myapp:latest .
docker run --rm myapp:latest
docker image inspect myapp:latest --format '{{.Size}}'

期待結果: コンテナが起動し、期待されるポートで応答し、非rootとして実行される。

失敗時: docker logsでログを確認する。WORKDIR、COPYパス、公開ポートを確認する。

バリデーション

  • docker buildがエラーなく完了する
  • コンテナが起動しアプリケーションが応答する
  • .dockerignoreが不要なファイルを除外している
  • アプリケーションが非rootユーザーとして実行される
  • 依存関係がソースコードの前にコピーされている(キャッシュ効率)
  • シークレットや.envファイルがイメージに焼き込まれていない

よくある落とし穴

  • 依存関係インストール前のCOPY: コード変更のたびに依存関係キャッシュが無効化される。常にマニフェストファイルを先にコピーする
  • rootでの実行: デフォルトのDockerユーザーはroot。本番環境では常に非rootユーザーを追加する
  • .dockerignoreの不足: node_modules.gitをビルドコンテキストに送ると時間とディスクを浪費する
  • ベースイメージにlatestタグを使用: 再現性のため特定バージョン(例: node:22.11.0)に固定する
  • --no-cache-dirの忘れ: Pythonのpipはデフォルトでパッケージをキャッシュし、イメージを肥大化させる
  • ADD vs COPY: URLダウンロードやtar展開が不要な限りCOPYを使用する(ADDは自動展開する)

関連スキル

  • create-r-dockerfile - rockerイメージを使用するR固有のDockerfile
  • create-multistage-dockerfile - 最小限の本番イメージ用マルチステージパターン
  • optimize-docker-build-cache - 高度なキャッシュ戦略
  • setup-compose-stack - コンテナ化されたアプリを他のサービスとオーケストレーション

GitHub Repository

pjt222/agent-almanac
Pfad: i18n/ja/skills/create-dockerfile
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Verwandte Skills

content-collections

Meta

Diese Skill bietet eine produktionsgetestete Einrichtung für Content Collections – ein TypeScript-first-Tool, das Markdown/MDX-Dateien in typsichere Datensammlungen mit Zod-Validierung umwandelt. Verwenden Sie ihn beim Erstellen von Blogs, Dokumentationsseiten oder inhaltsstarken Vite + React-Anwendungen, um Typsicherheit und automatische Inhaltsvalidierung zu gewährleisten. Er behandelt alles von der Vite-Plugin-Konfiguration und MDX-Kompilierung bis hin zur Deployment-Optimierung und Schema-Validierung.

Skill ansehen

polymarket

Meta

Diese Fähigkeit ermöglicht es Entwicklern, Anwendungen mit der Polymarket-Prognosemärkte-Plattform zu erstellen, einschließlich API-Integration für Handel und Marktdaten. Sie bietet außerdem Echtzeit-Datenstreaming über WebSocket, um Live-Trades und Marktaktivitäten zu überwachen. Nutzen Sie sie zur Implementierung von Handelsstrategien oder zur Erstellung von Tools, die Live-Marktaktualisierungen verarbeiten.

Skill ansehen

creating-opencode-plugins

Meta

Diese Fähigkeit unterstützt Entwickler dabei, OpenCode-Plugins zu erstellen, die in über 25 Ereignistypen wie Befehle, Dateien und LSP-Operationen eingreifen. Sie bietet die Plugin-Struktur, Event-API-Spezifikationen und Implementierungsmuster für JavaScript/TypeScript-Module. Nutzen Sie sie, wenn Sie den Lebenszyklus des OpenCode KI-Assistenten mit benutzerdefinierter ereignisgesteuerter Logik abfangen, überwachen oder erweitern müssen.

Skill ansehen

sglang

Meta

SGLang ist ein hochperformantes LLM-Serving-Framework, das sich auf schnelle, strukturierte Generierung für JSON, Regex und agentenbasierte Workflows unter Verwendung seines RadixAttention-Prefix-Cachings spezialisiert. Es bietet deutlich schnellere Inferenz, insbesondere für Aufgaben mit wiederholten Präfixen, was es ideal für komplexe, strukturierte Ausgaben und Mehrfachdialoge macht. Wählen Sie SGLang gegenüber Alternativen wie vLLM, wenn Sie constrained decoding benötigen oder Anwendungen mit umfangreicher Präfix-Weitergabe entwickeln.

Skill ansehen