MCP HubMCP Hub
Retour aux compétences

optimize-docker-build-cache

pjt222
Mis à jour 2 days ago
6 vues
17
2
17
Voir sur GitHub
Métadesign

À propos

Cette compétence Claude aide à optimiser les builds Docker en améliorant la mise en cache des couches, en mettant en œuvre des builds multi-étapes et en tirant parti de BuildKit pour réduire les temps de build et la taille des images. Elle fournit des stratégies de mise en cache spécifiques aux langages pour optimiser les pipelines CI/CD. Utilisez-la lorsque les builds Docker sont lents, que les images sont inutilement volumineuses ou que vous avez besoin de rationaliser les workflows de conteneurisation.

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/optimize-docker-build-cache

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

Documentation


name: optimize-docker-build-cache locale: es source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16 description: > Optimizar la caché de compilación de Docker para reducir tiempos de compilación y tamaños de imagen. Cubrir el orden de capas, compilaciones multi-etapa, BuildKit, y estrategias de caché para diferentes lenguajes. Usar cuando las compilaciones Docker son lentas, las imágenes son innecesariamente grandes, o cuando se necesita optimizar pipelines CI/CD. license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: intermediate language: multi tags: docker, build-cache, optimization, multi-stage, buildkit

Optimizar Caché de Compilación Docker

Optimizar las compilaciones Docker con estrategias de caché de capas, compilaciones multi-etapa y BuildKit.

Cuándo Usar

  • Las compilaciones Docker son lentas (>5 minutos para cambios de código)
  • Las imágenes Docker son innecesariamente grandes (>1GB)
  • Los pipelines CI/CD gastan mucho tiempo en compilaciones Docker
  • Recompilando dependencias sin cambios cada vez
  • Necesitando optimizar costos de infraestructura CI/CD

Entradas

  • Requerido: Dockerfile existente a optimizar
  • Requerido: Conocimiento de los patrones de cambio del proyecto (qué cambia frecuentemente)
  • Opcional: Infraestructura CI/CD utilizada (GitHub Actions, GitLab CI, etc.)
  • Opcional: Registry de imágenes para caché remota

Procedimiento

Paso 1: Ordenar Capas por Frecuencia de Cambio

Organizar las instrucciones del Dockerfile de menos a más frecuentemente cambiadas.

# CORRECTO: Dependencias antes del código
FROM node:20-alpine

# 1. Dependencias del sistema (cambian raramente)
RUN apk add --no-cache python3 make g++

# 2. Archivos de dependencias (cambian ocasionalmente)
COPY package.json package-lock.json ./
RUN npm ci --production

# 3. Código fuente (cambia frecuentemente)
COPY . .

# 4. Compilación (depende del código)
RUN npm run build
# INCORRECTO: Todo junto (invalida caché en cada cambio)
FROM node:20-alpine
COPY . .
RUN npm ci && npm run build

Esperado: Las recompilaciones solo reejecutarán las capas afectadas por los cambios, no todas las capas.

En caso de fallo: Analizar qué archivos cambian frecuentemente con git log --stat, reestructurar COPY para separar archivos estables de los que cambian.

Paso 2: Usar Compilaciones Multi-Etapa

Separar las dependencias de compilación de la imagen final.

# Etapa de compilación
FROM golang:1.21 AS builder
WORKDIR /app
COPY go.mod go.sum ./
RUN go mod download
COPY . .
RUN CGO_ENABLED=0 go build -o server .

# Etapa de producción
FROM alpine:3.18
RUN apk add --no-cache ca-certificates
COPY --from=builder /app/server /usr/local/bin/server
CMD ["server"]

Esperado: La imagen final contiene solo el binario y dependencias de runtime, reduciendo significativamente el tamaño.

En caso de fallo: Verificar que todos los archivos necesarios se copian desde la etapa de compilación, probar la imagen final exhaustivamente.

Paso 3: Habilitar BuildKit

Usar BuildKit para caché avanzada y compilaciones paralelas.

# Habilitar BuildKit
export DOCKER_BUILDKIT=1

# O en docker compose
COMPOSE_DOCKER_CLI_BUILD=1 DOCKER_BUILDKIT=1 docker compose build

# Compilar con caché de montaje (para gestores de paquetes)
# syntax=docker/dockerfile:1
FROM python:3.11-slim

# Caché de pip con montaje
RUN --mount=type=cache,target=/root/.cache/pip \
    pip install -r requirements.txt

Esperado: BuildKit habilitado, las compilaciones usan caché de montaje para gestores de paquetes, compilaciones paralelas cuando es posible.

En caso de fallo: Verificar versión de Docker (BuildKit requiere 18.09+), agregar # syntax=docker/dockerfile:1 al inicio del Dockerfile.

Paso 4: Configurar Caché Remota para CI/CD

Usar caché de registry para persistir la caché entre compilaciones CI.

# Compilar con caché en registry
docker buildx build \
  --cache-from type=registry,ref=myregistry.com/myapp:cache \
  --cache-to type=registry,ref=myregistry.com/myapp:cache,mode=max \
  -t myapp:latest .
# GitHub Actions
- name: Build and push
  uses: docker/build-push-action@v5
  with:
    cache-from: type=gha
    cache-to: type=gha,mode=max

Esperado: La caché persiste entre ejecuciones CI/CD, las compilaciones subsecuentes son significativamente más rápidas.

En caso de fallo: Verificar permisos del registry, comprobar que la caché se descarga correctamente, monitorizar el tamaño de la caché.

Validación

  • Las compilaciones con cambios solo de código no reinstalan dependencias
  • Las compilaciones multi-etapa producen imágenes significativamente más pequeñas
  • BuildKit está habilitado y la caché de montaje funciona
  • La caché CI/CD reduce los tiempos de compilación en >50%
  • Las imágenes de producción no contienen herramientas de compilación

Errores Comunes

  • COPY . . antes de dependencias: Invalida la caché de dependencias en cada cambio de código. Siempre copiar archivos de bloqueo primero.
  • No usar .dockerignore: Archivos innecesarios (node_modules, .git) invalidan la caché. Crear .dockerignore apropiado.
  • Caché no persiste en CI: Las compilaciones CI comienzan limpias. Usar caché de registry o caché específica del CI.
  • Imagen final demasiado grande: Olvidar la compilación multi-etapa. Nunca instalar compiladores en la imagen final.
  • Capas RUN separadas innecesarias: Combinar comandos relacionados con && para reducir capas.

Habilidades Relacionadas

  • create-dockerfile - Crear Dockerfiles generales con mejores prácticas
  • create-r-dockerfile - Optimización específica para proyectos R
  • build-ci-cd-pipeline - Integrar compilaciones Docker optimizadas en CI/CD
  • create-multistage-dockerfile - Patrones avanzados de compilación multi-etapa

Dépôt GitHub

pjt222/agent-almanac
Chemin: i18n/es/skills/optimize-docker-build-cache
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