push-to-registry

Par hashicorp · agent-skills

Envoyez les métadonnées de build Packer vers le registre HCP Packer pour suivre et gérer le cycle de vie des images. À utiliser lors de l'intégration des builds Packer avec HCP Packer pour le contrôle de version et la gouvernance.

npx skills add https://github.com/hashicorp/agent-skills --skill push-to-registry

Push to HCP Packer Registry

Configurez les templates Packer pour envoyer les métadonnées de build au registre HCP Packer.

Référence : HCP Packer Registry

Note : HCP Packer est gratuit pour un usage basique. Les builds poussent uniquement des métadonnées (pas les images elles-mêmes), ajoutant un surcoût minimal (<1 minute).

Basic Registry Configuration

packer {
  required_version = ">= 1.7.7"
}

variable "image_name" {
  type    = string
  default = "web-server"
}

locals {
  timestamp = regex_replace(timestamp(), "[- TZ:]", "")
}

source "amazon-ebs" "ubuntu" {
  region        = "us-west-2"
  instance_type = "t3.micro"

  source_ami_filter {
    filters = {
      name = "ubuntu/images/*ubuntu-jammy-22.04-amd64-server-*"
    }
    most_recent = true
    owners      = ["099720109477"]
  }

  ssh_username = "ubuntu"
  ami_name     = "${var.image_name}-${local.timestamp}"
}

build {
  sources = ["source.amazon-ebs.ubuntu"]

  hcp_packer_registry {
    bucket_name = var.image_name
    description = "Ubuntu 22.04 base image for web servers"

    bucket_labels = {
      "os"   = "ubuntu"
      "team" = "platform"
    }

    build_labels = {
      "build-time" = local.timestamp
    }
  }

  provisioner "shell" {
    inline = [
      "sudo apt-get update",
      "sudo apt-get upgrade -y",
    ]
  }
}

Authentication

Définissez les variables d'environnement avant de lancer le build :

export HCP_CLIENT_ID="your-service-principal-client-id"
export HCP_CLIENT_SECRET="your-service-principal-secret"
export HCP_ORGANIZATION_ID="your-org-id"
export HCP_PROJECT_ID="your-project-id"

packer build .

Create HCP Service Principal

  1. Accédez à HCP → Access Control (IAM)
  2. Créez un Service Principal
  3. Accordez le rôle « Contributor » sur le projet
  4. Générez un client secret
  5. Sauvegardez le client ID et le secret

Registry Configuration Options

bucket_name (required)

L'identifiant de l'image. Doit rester cohérent entre les builds !

bucket_name = "web-server"  # Keep this constant

bucket_labels (optional)

Métadonnées au niveau du bucket. Mises à jour à chaque build.

bucket_labels = {
  "os"        = "ubuntu"
  "team"      = "platform"
  "component" = "web"
}

build_labels (optional)

Métadonnées pour chaque itération. Immuables après la fin du build.

build_labels = {
  "build-time" = local.timestamp
  "git-commit" = var.git_commit
}

CI/CD Integration

GitHub Actions

name: Build and Push to HCP Packer

on:
  push:
    branches: [main]

env:
  HCP_CLIENT_ID: ${{ secrets.HCP_CLIENT_ID }}
  HCP_CLIENT_SECRET: ${{ secrets.HCP_CLIENT_SECRET }}
  HCP_ORGANIZATION_ID: ${{ secrets.HCP_ORGANIZATION_ID }}
  HCP_PROJECT_ID: ${{ secrets.HCP_PROJECT_ID }}

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - uses: hashicorp/setup-packer@main

      - name: Build and push
        run: |
          packer init .
          packer build \
            -var "git_commit=${{ github.sha }}" \
            .

Querying in Terraform

data "hcp_packer_artifact" "ubuntu" {
  bucket_name  = "web-server"
  channel_name = "production"
  platform     = "aws"
  region       = "us-west-2"
}

resource "aws_instance" "web" {
  ami           = data.hcp_packer_artifact.ubuntu.external_identifier
  instance_type = "t3.micro"

  tags = {
    PackerBucket = data.hcp_packer_artifact.ubuntu.bucket_name
  }
}

Common Issues

Authentication Failed

  • Vérifiez HCP_CLIENT_ID et HCP_CLIENT_SECRET
  • Assurez-vous que le service principal a le rôle Contributor
  • Vérifiez les IDs d'organisation et de projet

Bucket Name Mismatch

  • Gardez bucket_name cohérent entre les builds
  • N'incluez pas de timestamps dans bucket_name
  • Crée un nouveau bucket si le nom change

Build Fails

  • Packer échoue immédiatement s'il ne peut pas pousser les métadonnées
  • Prévient les divergences entre les artefacts et le registre
  • Vérifiez la connectivité réseau vers l'API HCP

Best Practices

  • Noms de bucket cohérents - Ne changez jamais pour le même type d'image
  • Labels significatifs - Utilisez-les pour les versions, les équipes, la conformité
  • Automatisation CI/CD - Automatisez les builds et les pushes vers le registre
  • Build labels immuables - Placez les données changeantes (git SHA, date) dans build_labels

References

Skills similaires