Questo documento fornisce una panoramica dell'automazione del deployment.
Puoi configurare Cloud Deploy in modo da eseguire automaticamente le attività relative alle release e all'implementazione per una determinata pipeline di distribuzione. Queste attività includono uscita promozione e avanzamento di fase.
Scopri di più sulle risorse utilizzate per e rilasciare l'automazione in Cloud Deploy.
Scopri di più su come configurare le regole che definiscono il funzionamento di queste automazioni.
Azioni che puoi automatizzare
In Cloud Deploy, puoi automatizzare le seguenti attività di rilascio e implementazione:
-
Puoi configura Cloud Deploy per promuovere la release automaticamente, al termine dell'implementazione in una destinazione. Ad esempio, se disponi tre target,
dev
,staging
eprod
, puoi configurare un'automazione in modo che la release venga promossa aprod
, senza ulteriori persone interazione, dopo un corretto deployment instaging
. -
Puoi configurare Cloud Deploy per far progredire un'implementazione da una fase a quella successiva, dopo un'implementazione corretta per il target precedente. L'avanzamento della fase è disponibile solo nei target che utilizzano una strategia di deployment canary.
-
Puoi configurare Cloud Deploy in modo da riprovare automaticamente un rollout non riuscito. Sono inclusi il nuovo tentativo di implementazione un numero specificato di volte e il rollback automatico se questo numero di tentativi non va a buon fine.
Consulta le regole di automazione per saperne di più su queste azioni e come configurarle.
Come funziona l'automazione?
Ogni automazione è collegata alla pipeline di importazione per la quale viene utilizzata. Non puoi condivide un'automazione tra più pipeline di distribuzione.
Di seguito è riportato il processo generale per la configurazione e l'esecuzione di un automazione:
-
Questa automazione è associata a una pipeline di distribuzione.
Registri l'automazione utilizzando
gcloud deploy apply
.Viene creata la risorsa automazione.
Puoi richiamare la pipeline di distribuzione associata a questa automazione creando una release.
L'implementazione va a buon fine per almeno un target o non va a buon fine.
Se l'implementazione va a buon fine e l'automazione è
promoteReleaseRule
:L'esecuzione attende che l'implementazione vada a buon fine nel target di origine. La destinazione di origine è il
selector.targets
configurato per l'automazione, non nelAutomationRule
.Se è configurato un orario
wait
, l'esecuzione attende anche questo orario.La release viene promossa automaticamente al target successivo nella progressione della pipeline o a un target specifico, se indicato.
Se l'implementazione va a buon fine e l'automazione è
advanceRolloutRule
e il target utilizza una strategia di deployment canary:L'esecuzione attende l'identificazione fase di origine, se disponibile.
La proprietà
sourcePhase
è facoltativa e se non sono presenti fasi sorgente specificato, ogni fase dell'implementazione viene avanzata automaticamente. La l'avanzamento automatico della fase avviene quando la fase di origineIN_PROGRESS
, soggetto await
volta.Se è configurato un orario
wait
, l'esecuzione attende anche questo orario.Quando automatizza un deployment canary, utilizzerai questo tempo di attesa per specificare la durata di ogni fase canary.
L'implementazione passa automaticamente dalla fase di origine a quella successiva durante l'implementazione.
Se c'è una fase di origine aggiuntiva, viene trattata allo stesso modo, includendo stesso tempo di attesa, se applicabile.
Se l'implementazione non va a buon fine ed è presente un'automazione con una regola
repairRollout
:Viene eseguito un nuovo tentativo di implementazione dopo l'ora
wait
configurata, se presente.Se in questa regola
repairRollout
sono configurate fasi o job specifici, viene eseguito un nuovo tentativo solo per queste fasi o questi job. L'impostazione predefinita, se nessun job o nessun job del deployment, consiste nel riprovare tutte le fasi e i job nell'implementazione.Poiché i nuovi tentativi sono facoltativi, se l'automazione non è configurata su riprova, questo passaggio non succede.
Se il primo tentativo non va a buon fine, l'esecuzione attende il tempo
wait
configurato, poi riprova.Le ripetizioni vengono ripetute finché Cloud Deploy non ha esaurito il numero di tentativi
attempts
.Se tutti i tentativi falliscono e i
attempts
sono esauriti, l'implementazione non va a buon fine.Durante i nuovi tentativi, l'implementazione stato è
IN_PROGRESS
finché l'implementazione non va a buon fine o non riesce a seguire il ultimo tentativo di nuovo. Lo stato della fase èIN_PROGRESS
durante i tentativi di ripetizione, maFAILED
dopo ogni fallimento dell'implementazione.Se tutti i tentativi non vanno a buon fine (o non ne è stato configurato nessuno), viene creata una nuova implementazione per eseguire il rollback alla release riuscita più recente nel target.
Risorse di Automation
Esistono due risorse Cloud Deploy specifiche per l'automazione:
Automazione
Un
Automation
è una risorsa secondaria di una pipeline di importazione e include le seguenti informazioni:- Un puntatore al target o ai target per cui viene utilizzata l'automazione
- La regola o le regole che regolano cosa fa l'automazione e come lo fa
La configurazione della risorsa di Automation è descritta nel documento Informazioni sulla risorsa di automazione.
Quando esegui
gcloud deploy apply
su un file che include un'automazione (kind: Automation
), Cloud Deploy crea un'istanza risorse di automazione, che associa una pipeline di distribuzione e una o più destinazioni a uno o più regole di automazione.Esecuzione automazione
AutomationRun
è un'istanza di un'automazione. È un puntatore alla sua risorsa di Automation corrispondente, più informazioni sull'implementazione e altri metadati.L'esecuzione dell'automazione viene creata quando viene attivata un'automazione.
Scopri di più sulle risorse di automazione.
Regole di Automation
Una regola di automazione definisce un'azione che può essere eseguita automaticamente sulla pipeline di distribuzione, nonché i dettagli su come deve essere eseguita l'automazione.
Scopri di più sulle regole di automazione.
Ruoli e autorizzazioni di Identity and Access Management richiesti
Oltre alle autorizzazioni necessarie per eseguire qualsiasi pipeline di distribuzione Cloud Deploy e per eseguire le attività da automatizzare (ad esempio l'avanzamento di un rollout), sono necessarie diverse autorizzazioni per eseguire determinate operazioni sulle risorse Automation
e 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
Oltre a queste autorizzazioni, ogni regola di automazione potrebbe richiedere ulteriori autorizzazioni per eseguire l'operazione automatica. Consulta Configurare le regole di automazione per conoscere le autorizzazioni specifiche necessarie per ogni regola di automazione.
Per ulteriori informazioni, tra cui i ruoli Cloud Deploy che includono queste autorizzazioni, consulta Ruoli e autorizzazioni IAM.
Crea un'automazione
Puoi creare un'automazione, ad esempio utilizzare una qualsiasi delle
regole di automazione disponibili,
configurando un'automazione e creando poi la risorsa di automazione
gcloud deploy apply
Consulta la sezione seguente (Configurazione dell'automazione) e Configurazione delle regole di automazione.
Configurazione dell'automazione
Consulta lo schema del file di configurazione per informazioni dettagliate su come configurare la risorsa Automation
.
Configurazione delle regole di Automation
Oltre a questa configurazione di automazione, specifica regole di automazione. La configurazione è diversa per ciascuna delle regole disponibili.
Consulta Utilizzare le regole di automazione per le descrizioni di ciascuna delle regole disponibili.
Sospendere un'automazione
Puoi sospendere una risorsa esistente senza eliminarla. Può essere utile per testare un'automazione senza influire sulla pipeline di distribuzione. Quando interrompi un'automazione, questa non viene eseguita, ma vengono comunque generati i log della piattaforma.
Nella configurazione
Automation
, aggiorna la proprietàsuspended
sutrue
.Esegui
gcloud deploy apply
sul file di configurazione.I log della piattaforma vengono comunque generati quando viene creata un'istanza dell'automazione, anche se è sospesa. Puoi utilizzarlo per testare e eseguire il debug dell'automazione senza influire sulla pipeline di importazione.
Passaggi successivi
Prova la guida rapida: automatizzare la creazione delle release e l'avanzamento dell'implementazione.
Scopri di più su Cloud Deploy regole di automazione.
Scopri di più su Cloud Deploy di automazione delle risorse.
Consulta le documentazione sullo schema dei file di configurazione per maggiori dettagli sui file di configurazione dell'automazione.