Utiliser Skaffold avec Cloud Deploy

Cet article décrit Skaffold, comment et pourquoi Cloud Deploy l'utilise, et ce que vous devez faire pour en profiter.

Cloud Deploy utilise Skaffold pour les opérations de rendu et de déploiement. Vous pouvez également l'utiliser pour le développement local, la compilation et les tests, ainsi que pour des fonctionnalités de déploiement avancées. Cependant, Cloud Deploy ne nécessite qu'une configuration Skaffold qui identifie les fichiers manifestes à afficher et à appliquer.

Qu'est-ce que Skaffold ?

Skaffold est un outil de ligne de commande qui permet le développement continu pour les applications Kubernetes natives. Skaffold vous permet de configurer un espace de travail de développement local à utiliser avec les pipelines de livraison continue Cloud Deploy.

Skaffold inclut les fonctionnalités suivantes:

  • Elle vous donne un contrôle discret sur les activités du pipeline CI/CD (création, rendu, déploiement test, etc.).

  • Il s'agit d'un outil de développement local.

  • Les profils Skaffold vous permettent de différencier différents environnements, avec différentes configurations de compilation, de test et de déploiement, le tout dans le même fichier de configuration.

Pourquoi Cloud Deploy utilise-t-il Skaffold ?

Google Cloud Deploy utilise Skaffold pour séparer les outils de rendu du pipeline de livraison. Votre pipeline de livraison définit simplement la progression de la cible à la cible, tandis que la configuration Skaffold définit les fichiers manifestes affichés et le mode d'affichage. Cela rend le rendu du fichier manifeste flexible sans affecter la façon dont vous définissez votre pipeline de livraison.

Voici quelques-uns des avantages offerts par Skaffold lorsque vous l'utilisez avec Cloud Deploy:

  • Processus d'intégration facile

    Commencez par une boucle de développement local. Vous pouvez partager votre fichier skaffold.yaml avec votre équipe, ce qui favorise la cohérence et aide les nouveaux membres de l'équipe.

  • Contrôle cohérent du rendu pour diverses cibles de déploiement

    Vous pouvez utiliser des profils Skaffold, avec des rendus et des déploiements différents selon les cibles.

  • Choix des outils de rendu sans compromettre la définition des pipelines de livraison

    L'utilisation de Skaffold permet à Cloud Deploy de séparer la définition du pipeline de livraison des détails de rendu. Cette séparation vous permet de tester vos fichiers manifestes sans perturber le pipeline de livraison.

  • Processus d'affichage cohérent

    La source de rendu et vos conteneurs permettent de générer les fichiers manifestes affichés.

  • Vérifications de l'état du déploiement

    Skaffold les exécute, et Cloud Deploy les utilise.

Comment Cloud Deploy utilise-t-il Skaffold ?

  • La source de rendu et les références aux images de conteneur sont transmises à Cloud Deploy lorsque vous créez une version.

    Lors de la création de la version, Cloud Deploy appelle Cloud Build, qui appelle à son tour skaffold diagnose et skaffold render pour afficher le ou les fichiers manifestes à l'aide de cette source de rendu et de ces images.

  • Vous pouvez utiliser des profils Skaffold pour différencier les fichiers manifestes qui seront appliqués à différentes cibles.

  • Cloud Deploy est compatible avec les modules Skaffold statiques.

  • Lors du déploiement, Cloud Deploy appelle skaffold apply pour appliquer le ou les fichiers manifestes affichés au cluster cible.

  • Cloud Deploy n'est pas compatible avec l'utilisation d'autres déployeurs pour déployer votre application, sauf si vous utilisez des cibles personnalisées. Toutefois, vous pouvez utiliser des outils tels que Helm ou Kustomize comme moteurs de rendu. Pour en savoir plus sur le déploiement de Cloud Deploy sans utiliser de déployeurs spécifiques (comme Helm), consultez la page Architecture du service.

Tirez parti de Skaffold

  1. Configurez Skaffold en fonction des besoins de votre pipeline.

    1. Déterminer les besoins de votre pipeline de livraison

      Combien de cibles aurez-vous ? le rendu et le déploiement sont identiques pour chacun. Si la configuration est la même pour chaque cible de votre progression, vous n'avez pas besoin d'utiliser de profils Skaffold. Vous n'avez besoin que d'un fichier skaffold.yaml qui décrit les fichiers manifestes à afficher.

    2. Le cas échéant, créez un profil Skaffold pour chaque cible.

      Définissez-le dans le fichier skaffold.yaml et associez-le à la séquence de progression de la définition de votre pipeline de livraison.

      Pour en savoir plus sur les profils Skaffold, consultez la documentation Skaffold. En outre, le document Gérer les fichiers manifestes dans Cloud Deploy inclut des exemples de configuration de profil.

    3. Définir le niveau de verbosité de la journalisation Skaffold

      Par défaut, le niveau de journalisation Skaffold est défini sur warn. Vous pouvez remplacer cela par debug dans la configuration de l'environnement d'exécution d'une cible en définissant verbose: true.

  2. Connectez Cloud Deploy à votre système d'intégration continue.

    À la fin de votre processus d'intégration continue, transmettez le skaffold.yaml, la source de rendu et les images de conteneur à insérer dans le fichier manifeste affiché.

  3. Facultatif: configurez votre boucle de développement local à l'aide de Skaffold.

    L'utilisation de Skaffold pour le développement est facultative dans Cloud Deploy. Le seul élément requis pour que Cloud Deploy fonctionne est un fichier skaffold.yaml qui identifie les fichiers manifestes à afficher.

Étapes suivantes

  • Consultez le site Skaffold pour découvrir son fonctionnement et ses avantages.

  • Découvrez comment Cloud Deploy sélectionne la version de Skaffold à utiliser, en cas de modification de la version et comment identifier la version actuellement utilisée.

  • Découvrez comment utiliser les profils Skaffold conjointement avec des outils avancés de gestion des fichiers manifestes tels que Helm, Kustomize et Kpt.

  • Suivez le tutoriel sur les profils Skaffold.