MCP HubMCP Hub
Retour aux compétences

create-dockerfile

pjt222
Mis à jour 2 days ago
7 vues
17
2
17
Voir sur GitHub
Métageneral

À propos

Cette compétence Claude crée des Dockerfiles prêts pour la production pour les projets Node.js, Python, Go, Rust et Java. Elle gère la sélection de l'image de base, l'installation des dépendances, les permissions utilisateur, et la configuration des modèles COPY, ENTRYPOINT/CMD et .dockerignore. Utilisez-la lors de la première conteneurisation d'une application, pour préparer un déploiement cloud, ou si votre projet ne dispose pas de Dockerfile.

Installation rapide

Claude Code

Recommandé
Principal
npx skills add pjt222/agent-almanac -a claude-code
Commande PluginAlternatif
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternatif
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-dockerfile

Copiez et collez cette commande dans Claude Code pour installer cette compétence

Documentation


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 - コンテナ化されたアプリを他のサービスとオーケストレーション

Dépôt GitHub

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

Compétences associées

content-collections

Méta

Cette compétence propose une configuration éprouvée en production pour Content Collections, un outil axé sur TypeScript qui transforme des fichiers Markdown/MDX en collections de données typées de manière sûre avec une validation Zod. Utilisez-la lors de la création de blogs, de sites de documentation ou d'applications Vite + React riches en contenu pour garantir la sécurité de typage et la validation automatique du contenu. Elle couvre tout, de la configuration du plugin Vite et de la compilation MDX à l'optimisation des déploiements et la validation des schémas.

Voir la compétence

polymarket

Méta

Cette compétence permet aux développeurs de créer des applications avec la plateforme de marchés prédictifs Polymarket, incluant l'intégration d'API pour le trading et les données de marché. Elle fournit également une diffusion de données en temps réel via WebSocket pour surveiller les transactions en direct et l'activité du marché. Utilisez-la pour mettre en œuvre des stratégies de trading ou pour créer des outils traitant les mises à jour de marché en direct.

Voir la compétence

creating-opencode-plugins

Méta

Cette compétence aide les développeurs à créer des plugins OpenCode qui s'interconnectent avec plus de 25 types d'événements tels que les commandes, les fichiers et les opérations LSP. Elle fournit la structure du plugin, les spécifications de l'API événementielle et les modèles d'implémentation pour les modules JavaScript/TypeScript. Utilisez-la lorsque vous avez besoin d'intercepter, de surveiller ou d'étendre le cycle de vie de l'assistant IA OpenCode avec une logique personnalisée pilotée par les événements.

Voir la compétence

sglang

Méta

SGLang est un framework de service LLM haute performance spécialisé dans la génération rapide et structurée pour les workflows JSON, regex et agentiques grâce à son cache de préfixe RadixAttention. Il offre une inférence nettement plus rapide, particulièrement pour les tâches avec des préfixes répétés, ce qui le rend idéal pour les sorties complexes et structurées ainsi que les conversations multi-tours. Choisissez SGLang plutôt que des alternatives comme vLLM lorsque vous avez besoin d'un décodage contraint ou que vous construisez des applications avec un partage étendu de préfixes.

Voir la compétence