Ce document présente l'automatisation des déploiements.
Vous pouvez configurer Cloud Deploy pour qu'il exécute automatiquement les tâches liées à la publication et au déploiement pour un pipeline de livraison donné. Ces tâches incluent la promotion de la version et l'avancement par phase.
En savoir plus sur les ressources utilisées pour l'automatisation des versions dans Cloud Deploy
En savoir plus sur la configuration des règles qui définissent le fonctionnement de ces automatisations.
Actions que vous pouvez automatiser
Dans Cloud Deploy, vous pouvez automatiser les activités de publication et de déploiement suivantes:
Promouvoir une version
Vous pouvez configurer Cloud Deploy pour promouvoir automatiquement votre version, dès lors qu'un déploiement réussit sur une cible. Par exemple, si vous avez trois cibles,
dev
,staging
etprod
, vous pouvez configurer une automatisation de sorte que la version soit promue àprod
, sans aucune autre interaction humaine, en cas de déploiement réussi dansstaging
.Avancer un déploiement
Vous pouvez configurer Cloud Deploy pour faire avancer un déploiement d'une phase à la suivante, après un déploiement réussi sur la cible précédente. L'avancement de phase n'est disponible que dans les cibles qui utilisent une stratégie de déploiement Canary.
Comment fonctionne l'automatisation ?
Chaque automatisation est liée au pipeline de livraison pour lequel elle est utilisée. Vous ne pouvez pas partager une automatisation entre plusieurs pipelines de livraison.
Voici le processus général de configuration et d'exécution d'une automatisation:
Vous configurez une automatisation
Cette automatisation est associée à un pipeline de livraison.
Vous enregistrez cette automatisation à l'aide de
gcloud deploy apply
.La ressource Automation est créée.
Vous appelez le pipeline de livraison associé à cette automatisation en créant une version.
Le déploiement a réussi pour au moins une cible.
Dans la cible pour laquelle cette automatisation est configurée...
Si l'automatisation est
promoteReleaseRule
:L'exécution attend que le déploiement aboutisse sur la cible source. La cible source est la
selector.targets
configurée pour l'automatisation, et non dansAutomationRule
.Si une durée
wait
est configurée, l'exécution attend également cette heure.La version est automatiquement promue à la cible suivante dans la progression du pipeline ou à une cible spécifique, si indiquée.
Si l'automatisation est
advanceRolloutRule
et que la cible utilise une stratégie de déploiement Canary:L'exécution attend la phase source identifiée, le cas échéant.
La propriété
sourcePhase
est facultative. Si aucune phase source n'est spécifiée, chaque phase du déploiement est avancée automatiquement. L'avancement automatique de la phase se produit lorsque la phase source estIN_PROGRESS
, à condition qu'elle soit définie surwait
.Si une durée
wait
est configurée, l'exécution attend également cette heure.Lorsque vous automatisez un déploiement Canary, vous utilisez ce temps d'attente pour spécifier la durée de chaque phase Canary.
Le déploiement passe automatiquement de cette phase source à la phase suivante.
S'il existe une phase source supplémentaire, elle est traitée de la même manière, y compris le même temps d'attente, le cas échéant.
Ressources sur l'automatisation
Deux ressources Cloud Deploy sont spécifiquement conçues pour l'automatisation:
Automatisation
Un
Automation
est une ressource enfant d'un pipeline de livraison et inclut les informations suivantes:- Pointeur vers la ou les cibles pour lesquelles l'automatisation est utilisée
- La ou les règles qui régissent ce que fait l'automatisation et comment elle le fait
La configuration de la ressource Automation est décrite dans le document À propos de la ressource Automation.
Lorsque vous exécutez
gcloud deploy apply
sur un fichier qui inclut une configuration d'automatisation (kind: Automation
), Cloud Deploy crée une ressource d'automatisation, qui associe un pipeline de livraison et une ou plusieurs cibles à une ou plusieurs règles d'automatisation.Exécution de l'automatisation
AutomationRun
est une instance d'automatisation. Il pointe vers la ressource d'automatisation correspondante, ainsi que des informations sur le déploiement qui l'a générée et d'autres métadonnées.L'exécution de l'automatisation est créée lorsqu'une automatisation est déclenchée.
En savoir plus sur les ressources d'automatisation
Règles d'automatisation
Une règle d'automatisation définit une action pouvant être effectuée automatiquement sur votre pipeline de livraison, et fournit des détails sur la manière dont l'automatisation doit être effectuée.
En savoir plus sur les règles d'automatisation
Rôles et autorisations Identity and Access Management requis
En plus des autorisations dont vous avez besoin pour exécuter n'importe quel pipeline de livraison Cloud Deploy et pour effectuer les tâches d'automatisation (telles que la progression d'un déploiement), vous devez disposer de plusieurs autorisations afin d'effectuer certaines opérations sur les ressources Automation
et AutomationRun
:
clouddeploy.automations.create
clouddeploy.automations.delete
clouddeploy.automations.get
clouddeploy.automations.list
clouddeploy.automations.update
clouddeploy.automationRuns.cancel
clouddeploy.automationRuns.get
clouddeploy.automationRuns.list
En plus de ces autorisations, chaque règle d'automatisation peut nécessiter des autorisations supplémentaires pour effectuer l'opération automatisée. Consultez Configurer les règles d'automatisation pour connaître les autorisations spécifiques nécessaires par règle d'automatisation.
Consultez la section Rôles et autorisations IAM pour en savoir plus, y compris sur les rôles Cloud Deploy qui incluent ces autorisations.
Créer une automatisation
Vous pouvez créer une automatisation, y compris en utilisant l'une des règles d'automatisation disponibles, en configurant une automatisation, puis en créant la ressource d'automatisation à l'aide de gcloud deploy apply
.
Consultez la section suivante (Configurer l'automatisation) et Configurer des règles d'automatisation.
Configurer l'automatisation
Consultez le schéma du fichier de configuration pour en savoir plus sur la configuration de la ressource Automation
.
Configuration des règles d'automatisation
En plus de cette configuration d'automatisation, vous spécifiez des règles d'automatisation. La configuration est différente pour chacune des règles disponibles.
Consultez la section Utiliser des règles d'automatisation pour obtenir une description de chacune des règles disponibles.
Suspendre une automatisation
Vous pouvez suspendre une ressource existante sans la supprimer. Cela peut être utile pour tester une automatisation sans affecter le pipeline de livraison. Lorsque vous suspendez une automatisation, celle-ci n'est pas exécutée, mais des journaux de plate-forme sont quand même générés.
Dans la configuration
Automation
, remplacez la propriétésuspended
partrue
.Exécutez
gcloud deploy apply
sur ce fichier de configuration.Les journaux de plate-forme sont toujours générés lorsque l'automatisation est instanciée, même si elle est suspendue. Vous pouvez l'utiliser pour tester et déboguer l'automatisation sans affecter le pipeline de livraison.
Étapes suivantes
Consultez le guide de démarrage rapide: Automatiser la création et le déploiement de versions.
En savoir plus sur les règles d'automatisation Cloud Deploy
En savoir plus sur les ressources d'automatisation Cloud Deploy.
Pour en savoir plus sur les fichiers de configuration de l'automatisation, consultez la documentation sur les schémas de fichiers de configuration.