Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Attributo UpdatePolicy
Utilizzate l'UpdatePolicy
attributo per specificare come AWS CloudFormation gestisce gli aggiornamenti di determinate risorse durante le operazioni di aggiornamento dello stack.
Argomenti
Panoramica
Utilizzando l'UpdatePolicy
attributo, è possibile controllare come vengono aggiornate le seguenti risorse, come descritto di seguito:
-
AWS::AppStream::Fleet— CloudFormation può arrestare e avviare una flotta, il che comporta la sostituzione delle istanze del parco macchine. In questo modo, a tutte le istanze verranno applicate le ultime modifiche immediatamente dopo un aggiornamento dello stack.
-
AWS::AutoScaling::AutoScalingGroup— Con i gruppi Auto Scaling, è possibile utilizzare uno o più criteri di aggiornamento per controllare la modalità di gestione di determinati CloudFormation aggiornamenti. Queste politiche includono:
-
AutoScalingReplacingUpdate
eAutoScalingRollingUpdate
politiche: CloudFormation possono sostituire il gruppo Auto Scaling e le relative istanze con unaAutoScalingReplacingUpdate
policy oppure sostituire solo le istanze con una policy.AutoScalingRollingUpdate
Queste operazioni di sostituzione si verificano quando si apportano una o più delle seguenti modifiche:-
Modificare il gruppo Auto Scaling AWS::AutoScaling::LaunchConfiguration.
-
Modifica la proprietà
VPCZoneIdentifier
del gruppo con scalabilità automatica. -
Modifica la proprietà
LaunchTemplate
del gruppo con scalabilità automatica. -
Modifica la proprietà
PlacementGroup
del gruppo con scalabilità automatica. -
Aggiorna un gruppo con dimensionamento automatico che contiene istanze che non corrispondono all'attuale
LaunchConfiguration
.
Se sono specificate entrambe le policy,
AutoScalingReplacingUpdate
eAutoScalingRollingUpdate
, l'impostazione della proprietàWillReplace
sutrue
da la precedenza aAutoScalingReplacingUpdate
. -
-
AutoScalingScheduledAction
politica: questa politica si applica quando si aggiorna uno stack che include un gruppo Auto Scaling con azioni pianificate che ridimensionano il gruppo in momenti specifici. CloudFormation non può modificare la dimensione minima, la dimensione massima o la capacità desiderata del gruppo a meno che non siano state modificate esplicitamente nel modello di stack. Questa politica aiuta a prevenire eventuali aggiornamenti imprevisti che potrebbero interferire con le attività di scalabilità pianificate.
-
-
AWS::ElastiCache::ReplicationGroup— CloudFormation può modificare gli shard di un gruppo di replica aggiungendo o rimuovendo shard, anziché sostituire l'intera risorsa.
-
AWS::OpenSearchService::Domain e AWS::Elasticsearch::Domain(legacy): CloudFormation può aggiornare un dominio di OpenSearch servizio a una nuova versione di OpenSearch Elasticsearch senza sostituire l'intera risorsa.
-
AWS::Lambda::Alias— CloudFormation può eseguire una CodeDeploy distribuzione quando la versione cambia sull'alias.
Le sezioni che seguono descrivono la sintassi e le proprietà dell'UpdatePolicy
attributo supportato da ogni tipo di risorsa.
AppStream Politica di aggiornamento 2.0
Per interrompere una flotta AppStream 2.0 prima di un aggiornamento e riavviarla dopo un aggiornamento, utilizza la politica di aggiornamento AppStream 2.0.
Sintassi
JSON
{ "UpdatePolicy": { "StopBeforeUpdate": { "Type": "
Boolean
" }, "StartAfterUpdate": { "Type": "Boolean
" } } }
YAML
UpdatePolicy: StopBeforeUpdate: Type:
Boolean
StartAfterUpdate: Type:Boolean
StopBeforeUpdate
-
Arresta il parco istanze specificato prima dell'aggiornamento.
Required: No
StartAfterUpdate
-
Avvia il parco istanze specificato dopo l'aggiornamento.
Required: No
Policy AutoScalingReplacingUpdate
Per sostituire il gruppo Auto Scaling e le istanze in esso contenute, utilizzate la policy. AutoScalingReplacingUpdate
Prima di tentare un aggiornamento, assicurati di disporre di una EC2 capacità Amazon sufficiente per i tuoi gruppi di Auto Scaling vecchi e nuovi.
Sintassi
JSON
"UpdatePolicy" : { "AutoScalingReplacingUpdate" : { "WillReplace" :
Boolean
} }
YAML
UpdatePolicy: AutoScalingReplacingUpdate: WillReplace:
Boolean
Proprietà
WillReplace
-
Specifica se un gruppo con dimensionamento automatico e le istanze in esso contenute vengono sostituiti durante un aggiornamento. Durante la sostituzione, CloudFormation mantiene il vecchio gruppo fino al termine della creazione di quello nuovo. Se l'aggiornamento fallisce, CloudFormation puoi tornare al vecchio gruppo Auto Scaling ed eliminare il nuovo gruppo Auto Scaling.
Durante la CloudFormation creazione del nuovo gruppo, non scollega o collega alcuna istanza. Dopo aver creato correttamente il nuovo gruppo Auto Scaling, CloudFormation elimina il vecchio gruppo Auto Scaling durante il processo di pulizia.
Quando impostate il
WillReplace
parametro, ricordatevi di specificare una corrispondenza CreationPolicy. Se il numero minimo di istanze (specificato dallaMinSuccessfulInstancesPercent
proprietà) non segnala l'esito positivo entro ilTimeout
periodo specificato nellaCreationPolicy
policy, l'aggiornamento sostitutivo non riesce e torna CloudFormation al vecchio gruppo Auto Scaling.Tipo: Booleano
Required: No
Policy AutoScalingRollingUpdate
Per eseguire un aggiornamento continuo delle istanze in un gruppo di Auto Scaling anziché attendere che le attività di scaling sostituiscano gradualmente le istanze più vecchie con istanze più nuove, utilizza la policy. AutoScalingRollingUpdate
Questa politica offre la flessibilità di specificare se CloudFormation sostituire le istanze che si trovano in un gruppo di Auto Scaling in batch o tutte contemporaneamente senza sostituire l'intera risorsa.
Aspetti da considerare quando si utilizza una policy: AutoScalingRollingUpdate
-
Quando CloudFormation ripristina un aggiornamento, utilizza la
UpdatePolicy
configurazione specificata nel modello prima dell'aggiornamento corrente dello stack. Ad esempio, si modifica il valoreMaxBatchSize
da 1 a 10 inUpdatePolicy
, si esegue un aggiornamento dello stack e tale aggiornamento ha esito negativo. CloudFormation utilizzerà 1 come dimensione massima del batch quando esegue il rollback, non 10. Per evitare questo scenario, apportate le modificheUpdatePolicy
in un aggiornamento separato prima di qualsiasi aggiornamento al gruppo Auto Scaling che potrebbe avviare aggiornamenti continui. -
CloudFormation consiglia di specificare la
SuspendProcesses
proprietà per sospendere temporaneamente i processi di Amazon EC2 Auto Scaling che potrebbero interferire con l'aggiornamento continuo e causarne il fallimento. Per ulteriori informazioni, vedi Come posso aggiornare il mio gruppo Auto Scaling quando aggiorno il mio CloudFormationstack? -
CloudFormation supporta l'utilizzo degli hook del ciclo di vita di Amazon EC2 Auto Scaling all'avvio o alla chiusura delle istanze. In questo modo hai il tempo di eseguire azioni personalizzate su un'istanza prima che passi allo stato successivo. Per assicurarti che le nuove istanze raggiungano lo
InService
stato, completa il lifecycle hook con unCONTINUE
risultato al termine dell'azione personalizzata. Per impostazione predefinita, se non viene ricevuta alcuna risposta e il lifecycle hook scade, l'avvio dell'istanza viene considerato non riuscito e abbandonato. Se nessuna istanza raggiungeInService
lo stato, l'aggiornamento progressivo finirà per fallire. -
Le funzionalità di Amazon EC2 Auto Scaling, come le politiche di manutenzione delle istanze, le politiche di terminazione e la protezione scalabile, non sono disponibili per l'uso con gli aggiornamenti continui. CloudFormation Pianifica i tuoi aggiornamenti periodici di conseguenza.
-
Se utilizzate un
AutoScalingRollingUpdate
criterio e rimuovete l'impostazione del gruppo di posizionamento, il gruppo di posizionamento verrà rimosso dal gruppo Auto Scaling e dal CloudFormation modello. Inoltre, ciò attiva un aggiornamento continuo, in modo che nuove istanze non vengano lanciate in un gruppo di collocamento.
Sintassi
JSON
"UpdatePolicy" : { "AutoScalingRollingUpdate" : { "MaxBatchSize" :
Integer
, "MinActiveInstancesPercent" :Integer
, "MinInstancesInService" :Integer
, "MinSuccessfulInstancesPercent" :Integer
, "PauseTime" :String
, "SuspendProcesses" : [List of processes
], "WaitOnResourceSignals" :Boolean
} }
YAML
UpdatePolicy: AutoScalingRollingUpdate: MaxBatchSize:
Integer
MinActiveInstancesPercent:Integer
MinInstancesInService:Integer
MinSuccessfulInstancesPercent:Integer
PauseTime:String
SuspendProcesses: -List of processes
WaitOnResourceSignals:Boolean
Proprietà
MaxBatchSize
-
Speciifica il numero massimo di istanze che possono essere sostituite contemporaneamente.
Default:
1
Maximum:
100
Tipo: integer
Required: No
MinActiveInstancesPercent
-
Speciifica la percentuale di istanze in un gruppo di Auto Scaling che devono trovarsi nello
InService
stato relativo alla capacità desiderata di quel gruppo durante un aggiornamento continuo affinché l'aggiornamento abbia esito positivo. È possibile specificare un valore compreso tra 0 e 100. CloudFormation arrotonda al decimo di percentuale più vicino. Ad esempio, se si aggiornano cinque istanze con unaInService
percentuale minima di 50, almeno tre istanze devono trovarsi nello stato.InService
Se un'istanza non passa alloInService
stato entro un periodo prestabilito di 1 ora, si CloudFormation presuppone che l'istanza non sia stata aggiornata.L'impostazione
MinActiveInstancesPercent
suUpdatePolicy
influirà anche sulle istanze avviate quando laDesiredCapacity
proprietà dellaAWS::AutoScaling::AutoScalingGroup
risorsa è impostata su un valore superiore alla capacità attualmente desiderata per quel gruppo di Auto Scaling.Default:
100
Tipo: integer
Required: No
MinInstancesInService
-
Speciifica il numero minimo di istanze che devono essere in servizio all'interno del gruppo Auto Scaling CloudFormation durante l'aggiornamento delle vecchie istanze. Questo valore deve essere inferiore a MaxSizedel gruppo Auto Scaling.
avvertimento
Si consiglia di impostare il valore della
MinInstancesInService
proprietà almeno su MinSizedel gruppo Auto Scaling. In questo modo si evitano potenziali problemi di disponibilità durante un aggiornamento progressivo dovuti al fatto che 0 istanze servono il traffico dei clienti.Default:
0
Tipo: integer
Required: No
MinSuccessfulInstancesPercent
-
Specifica la percentuale di istanze in un aggiornamento in sequenza Auto Scaling che devono essere segnalate come riuscite perché un aggiornamento riesca. È possibile specificare un valore compreso tra 0 e 100. CloudFormationarrotonda al decimo di percentuale più vicino. Ad esempio, se aggiorni cinque istanze con una percentuale di riuscita minima pari a
50
, tre istanze devono inviare segnali di successo. Se un'istanza non invia un segnale entro il tempo specificato nellaPauseTime
proprietà, CloudFormation presuppone che l'istanza non sia stata aggiornata.Si consiglia di impostare il valore della
MinSuccessfulInstancesPercent
proprietà su un valore maggiore di 0. Quando laMinSuccessfulInstancesPercent
proprietà è impostata su 0, CloudFormation attende che lo 0% delle istanze di capacità si trovi in unoInService
stato.MinSuccessfulInstancesPercent
ritorna immediatamente e prima di considerare lo stato del gruppo Auto ScalingUPDATE_COMPLETE
per passare alle risorse successive definite nel modello di stack. Se nel CloudFormation modello sono definiti altri gruppi di Auto Scaling, questi verranno aggiornati contemporaneamente. Quando tutti i gruppi con scalabilità automatica vengono implementati contemporaneamente con lo 0% delle istanze di capacità in uno statoInService
, si verificano problemi di disponibilità, in quanto 0 istanze gestiscono il traffico dei clienti.Default:
100
Tipo: integer
Required: No
PauseTime
-
La quantità di tempo che intercorre dopo aver apportato una modifica a un batch di istanze per dare a tali istanze il tempo di avviare le CloudFormation applicazioni software.
Specificate
PauseTime
nel formato di durata ISO86 01(nel formato PT
, dove ciascuno#
H#
M#
S#
corrisponde rispettivamente al numero di ore, minuti e secondi). Il valore massimo diPauseTime
è 1 ora (PT1H
).avvertimento
Quando
WaitOnResourceSignals
è impostato sutrue
,PauseTime
funge da valore di timeout. Determina il tempo massimo di CloudFormation attesa per ricevere il numero richiesto di segnali validi dalle istanze sostituite durante un aggiornamento continuo e dalle nuove istanze aggiunte aumentando il DesiredCapacityproprietà della risorsa.AWS::AutoScaling::AutoScalingGroup
SePauseTime
viene superato prima che CloudFormation riceva i segnali previsti, l'aggiornamento fallisce. Per ottenere risultati ottimali, specificate un periodo di tempo sufficiente per l'avvio delle applicazioni. Se deve essere eseguito il rollback dell'aggiornamento, unPauseTime
breve può comprometterne la riuscita.Impostazione predefinita:
PT5M
(5 minuti) quando laWaitOnResourceSignals
proprietà è impostata sutrue
. Altrimenti, non viene impostato alcun valore predefinito.Tipo: Stringa
Required: No
SuspendProcesses
-
Specifica i processi Auto Scaling da sospendere durante un aggiornamento dello stack. La sospensione dei processi impedisce ad Auto Scaling interferire con un aggiornamento dello stack. Ad esempio, puoi sospendere gli allarmi in modo che Amazon EC2 Auto Scaling non avvii le politiche di scalabilità associate a un allarme. Per i valori validi, consulta Types of process nella Amazon EC2 Auto Scaling User Guide.
Impostazione predefinita: non specificato
Tipo: elenco di processi Auto Scaling
Required: No
WaitOnResourceSignals
-
Speciifica se CloudFormation attende i segnali di successo provenienti da nuove istanze prima di continuare l'aggiornamento. CloudFormation attende i segnali di successo per la
PauseTime
durata specificata.Per segnalare il gruppo Auto Scaling, usa lo script di supporto cfn-signal. Per i gruppi di Auto Scaling associati a Elastic Load Balancing, prendi in considerazione l'aggiunta di un controllo dello stato per garantire che le istanze siano integre prima di segnalare l'esito positivo utilizzando lo script di supporto cfn-init. Per un esempio, consulta il
verify_instance_health
comando nei modelli di esempio per Amazon EC2 Auto Scaling che distribuisce gli aggiornamenti nel nostro GitHub repository.Default:
false
Tipo: Booleano
Obbligatorio: condizionale. Se si specifica la
MinSuccessfulInstancesPercent
proprietà, laWaitOnResourceSignals
proprietà deve essere impostata su.true
Policy AutoScalingScheduledAction
Per specificare in che modo CloudFormation gestisce gli aggiornamenti per MinSize
MaxSize
, e DesiredCapacity
le proprietà quando alla AWS::AutoScaling::AutoScalingGroup
risorsa è associata un'azione pianificata, utilizza la AutoScalingScheduledAction
politica.
Con le operazioni programmate, le proprietà delle dimensioni dei gruppi per un gruppo con dimensionamento automatico possono variare in qualsiasi momento. Quando aggiorni uno stack con un gruppo Auto Scaling e un'azione pianificata CloudFormation , imposta sempre i valori delle proprietà delle dimensioni del gruppo del gruppo Auto Scaling sui valori definiti nella risorsa AWS::AutoScaling::AutoScalingGroup
del modello, anche se è in corso un'azione pianificata.
Se non desideri modificare nessuno dei valori delle proprietà relative CloudFormation alla dimensione del gruppo quando hai in corso un'azione pianificata, utilizza il criterio di AutoScalingScheduledAction
aggiornamento e imposta in modo CloudFormation da IgnoreUnmodifiedGroupSizeProperties
true
evitare di modificare le DesiredCapacity
proprietà MinSize
MaxSize
, o a meno che tu non abbia modificato questi valori nel tuo modello.
Sintassi
JSON
"UpdatePolicy" : { "AutoScalingScheduledAction" : { "IgnoreUnmodifiedGroupSizeProperties" :
Boolean
} }
YAML
UpdatePolicy: AutoScalingScheduledAction: IgnoreUnmodifiedGroupSizeProperties:
Boolean
Proprietà
IgnoreUnmodifiedGroupSizeProperties
-
If
true
, CloudFormation ignora le differenze nelle proprietà delle dimensioni del gruppo tra il gruppo Auto Scaling corrente e il gruppo Auto Scaling descritto nella risorsa del modello durante un aggiornamentoAWS::AutoScaling::AutoScalingGroup
dello stack. Se modifichi uno qualsiasi dei valori della proprietà della dimensione del gruppo nel modello, CloudFormation utilizza i valori modificati e aggiorna il gruppo con scalabilità automatica.Default:
false
Tipo: Booleano
Required: No
Policy UseOnlineResharding
Per modificare gli shard di un gruppo di replica aggiungendo o rimuovendo shard, anziché sostituire l'intera risorsa AWS:::ElastiCache: ReplicationGroup, utilizza la policy di aggiornamento. UseOnlineResharding
Se UseOnlineResharding
è impostata sutrue
, è possibile aggiornare le NodeGroupConfiguration
proprietà NumNodeGroups
e le proprietà della AWS::ElastiCache::ReplicationGroup
risorsa e tali proprietà CloudFormation verranno aggiornate senza interruzioni. Quando UseOnlineResharding
è impostato false
su o non è specificato, l'aggiornamento delle NodeGroupConfiguration
proprietà NumNodeGroups
and comporta la CloudFormation sostituzione dell'intera AWS::ElastiCache::ReplicationGroup
risorsa.
La policy di aggiornamento UseOnlineResharding
non ha proprietà.
Aspetti da considerare quando si imposta la policy di aggiornamento UseOnlineResharding
su true
:
-
Ti consigliamo di eseguire gli aggiornamenti alle proprietà
NumNodeGroups
eNodeGroupConfiguration
come unici aggiornamenti in una determinata operazione di aggiornamento dello stack.L'aggiornamento della configurazione del gruppo di nodi di un gruppo di replica è un'operazione che richiede un uso intensivo delle risorse. Se un aggiornamento dello stack fallisce, CloudFormation non ripristina le modifiche alla configurazione del gruppo di nodi di un gruppo di replica. Tuttavia, CloudFormation ripristinerà tutte le altre proprietà che sono state modificate come parte dell'operazione di aggiornamento non riuscita.
-
Qualsiasi aggiornamento di gruppo di nodi richiede l'identificazione di tutti i gruppi di nodi.
Se si specifica la
NodeGroupConfiguration
proprietà, è necessario specificare anche la configurazione NodeGroupId per ogni gruppo di nodi per CloudFormation aggiornare il numero di nodi senza interruzioni.Quando si crea un gruppo di replica, se non si specifica un ID per ciascun gruppo di nodi, ElastiCache genera automaticamente un ID per ciascun gruppo di nodi. Per aggiornare il gruppo di replica senza interruzioni, utilizzate la ElastiCache console (https://console.aws.amazon.com/elasticache/
) o DescribeReplicationGroupsrecuperate il file IDs per tutti i gruppi di nodi del gruppo di replica. Quindi specifica l'ID per ciascun gruppo di nodi nel tuo modello di stack prima di tentare di aggiungere o rimuovere shard. Nota
Come best practice, quando crei un gruppo di replica in un modello di stack, includi un ID per ciascun gruppo di nodi specificato.
Inoltre, l'aggiornamento del numero di nodi senza interruzioni richiede che tu abbia specificato con precisione le proprietà
PrimaryAvailabilityZone
,ReplicaAvailabilityZones
eReplicaCount
per ciascunNodeGroupConfiguration
. Anche in questo caso, potete utilizzare la ElastiCache console (https://console.aws.amazon.com/elasticache/) o DescribeReplicationGroupsrecuperare i valori effettivi per ogni gruppo di nodi e confrontarli con i valori del modello di stack. Puoi aggiornare i valori di proprietà del gruppo di nodi come aggiornamento dello stack separato oppure come parte dello stesso aggiornamento dello stack che modifica il numero dei gruppi di nodi. Quando utilizzate una politica di
UseOnlineResharding
aggiornamento per aggiornare il numero di gruppi di nodi senza interruzioni, distribuisce ElastiCache uniformemente gli spazi chiave tra il numero di slot specificato. Questo non può essere aggiornato in un secondo momento. Pertanto, dopo l'aggiornamento del numero dei gruppi di nodi in questo modo, devi rimuovere il valore specificato per la proprietàSlots
di ciascunaNodeGroupConfiguration
dal modello dello stack, in quanto non riflette più i valori effettivi in ciascun gruppo di nodi. -
I risultati effettivi della rimozione del gruppo di nodi potrebbero variare
Quando si specifica un
NumNodeGroups
valore inferiore al numero corrente di gruppi di nodi, CloudFormation indica di ElastiCache rimuovere tutti i gruppi di nodi necessari per raggiungere il numero di nodi specificato. Tuttavia, ElastiCache potrebbe non essere sempre possibile rimuovere il numero desiderato di gruppi di nodi. Nel caso in cui non sia ElastiCache possibile rimuovere il numero desiderato di gruppi di nodi, CloudFormation genera un evento stack che avvisa l'utente in merito. Nei casi in cui non è ElastiCache possibile rimuovere alcun gruppo di nodi, l'aggiornamento delle CloudFormation risorse non riesce.
Per ulteriori informazioni sulla modifica dei gruppi di replica, consulta Amazon ModifyReplicationGroupShardConfiguration ElastiCache APIReference.
Sintassi
JSON
"UpdatePolicy" : { "UseOnlineResharding" :
Boolean
}
YAML
UpdatePolicy: UseOnlineResharding:
Boolean
Policy EnableVersionUpgrade
Per aggiornare un dominio di OpenSearch servizio a una nuova versione di OpenSearch Elasticsearch anziché sostituire l'intera risorsa::: :Domain o AWSAWS: :ElasticsearchOpenSearchService: :Domain, utilizza la politica di aggiornamento. EnableVersionUpgrade
Se EnableVersionUpgrade
è impostato sutrue
, è possibile aggiornare la EngineVersion
proprietà della AWS::OpenSearchService::Domain
risorsa (o la proprietà della AWS::Elasticsearch::Domain
risorsa legacy) e CloudFormation aggiornerà tale ElasticsearchVersion
proprietà senza interruzioni. Quando EnableVersionUpgrade
è impostato sufalse
, o non è specificato, l'aggiornamento della ElasticsearchVersion
proprietà EngineVersion
o comporta la CloudFormation sostituzione dell'intera AWS::Elasticsearch::Domain
risorsaAWS::OpenSearchService::Domain
/.
La policy di aggiornamento EnableVersionUpgrade
non ha proprietà.
Per ulteriori informazioni sull'aggiornamento dei domini di OpenSearch servizio, consulta UpgradeDomainl'Amazon OpenSearch Service Developer Guide.
Sintassi
JSON
"UpdatePolicy" : { "EnableVersionUpgrade" :
Boolean
}
YAML
UpdatePolicy: EnableVersionUpgrade:
Boolean
CodeDeployLambdaAliasUpdate politica
Per eseguire una CodeDeploy distribuzione quando la versione cambia su una AWS::Lambda::Alias
risorsa, utilizza la politica di CodeDeployLambdaAliasUpdate
aggiornamento.
Sintassi
JSON
"UpdatePolicy" : { "CodeDeployLambdaAliasUpdate" : { "AfterAllowTrafficHook" :
String
, "ApplicationName" :String
, "BeforeAllowTrafficHook" :String
, "DeploymentGroupName" :String
} }
YAML
UpdatePolicy: CodeDeployLambdaAliasUpdate: AfterAllowTrafficHook:
String
ApplicationName:String
BeforeAllowTrafficHook:String
DeploymentGroupName:String
Proprietà
AfterAllowTrafficHook
-
Il nome della funzione Lambda da eseguire dopo il completamento dell'instradamento del traffico.
Required: No
Tipo: Stringa
ApplicationName
-
Il nome dell' CodeDeploy applicazione.
Campo obbligatorio: sì
Tipo: Stringa
BeforeAllowTrafficHook
-
Il nome della funzione Lambda da eseguire prima dell'inizio dell'instradamento del traffico.
Required: No
Tipo: Stringa
DeploymentGroupName
-
Il nome del gruppo CodeDeploy di distribuzione. È dove viene impostata la policy di trasferimento del traffico.
Campo obbligatorio: sì
Tipo: Stringa
Per un esempio che specifica l'attributo UpdatePolicy
per una risorsa AWS::Lambda::Alias
, consulta Policy di aggiornamento dell'alias Lambda.
Esempi
I seguenti esempi mostrano come aggiungere una policy di aggiornamento a un gruppo con dimensionamento automatico e come garantire la disponibilità durante l'aggiornamento dei metadati.
Aggiunta di una UpdatePolicy
a un gruppo con scalabilità automatica
Il seguente esempio mostra come aggiungere una policy di aggiornamento. Durante un aggiornamento, il gruppo con dimensionamento automatico aggiorna le istanze in batch di due e mantiene in servizio almeno un'istanza. Poiché il flag WaitOnResourceSignals
è impostato, il gruppo con dimensionamento automatico attende nuove istanze che vengono aggiunte al gruppo. Le nuove istanze devono inviare il segnale al gruppo con dimensionamento automatico prima che aggiorni il batch di istanze successivo.
JSON
"ASG" : { "Type":"AWS::AutoScaling::AutoScalingGroup", "Properties":{ "VPCZoneIdentifier":[ "
subnetIdAz1
", "subnetIdAz2
", "subnetIdAz3
" ], "LaunchTemplate":{ "LaunchTemplateId":{ "Ref":"logicalName
" }, "Version":{ "Fn::GetAtt":[ "logicalName
", "LatestVersionNumber" ] } }, "MaxSize":"4", "MinSize":"1" }, "UpdatePolicy":{ "AutoScalingScheduledAction":{ "IgnoreUnmodifiedGroupSizeProperties":"true" }, "AutoScalingRollingUpdate":{ "MinInstancesInService":"1", "MaxBatchSize":"2", "WaitOnResourceSignals":"true", "PauseTime":"PT10M", "SuspendProcesses":[ "HealthCheck", "ReplaceUnhealthy", "AZRebalance", "AlarmNotification", "ScheduledActions", "InstanceRefresh" ] } } }
YAML
ASG: Type: 'AWS::AutoScaling::AutoScalingGroup' Properties: VPCZoneIdentifier: -
subnetIdAz1
-subnetIdAz2
-subnetIdAz3
LaunchTemplate: LaunchTemplateId: !ReflogicalName
Version: !GetAttlogicalName
.LatestVersionNumber MaxSize: '4' MinSize: '1' UpdatePolicy: AutoScalingScheduledAction: IgnoreUnmodifiedGroupSizeProperties: 'true' AutoScalingRollingUpdate: MinInstancesInService: '1' MaxBatchSize: '2' WaitOnResourceSignals: 'true' PauseTime: PT10M SuspendProcesses: - HealthCheck - ReplaceUnhealthy - AZRebalance - AlarmNotification - ScheduledActions - InstanceRefresh
AutoScalingReplacingUpdate politica
Nell'esempio seguente viene dichiarata una policy che impone la sostituzione di un gruppo con dimensionamento automatico associato durante un aggiornamento. Perché l'aggiornamento riesca, una percentuale di istanze (specificata dal parametro MinSuccessfulPercentParameter
) deve segnalare l'esito positivo entro il periodo Timeout
.
JSON
"UpdatePolicy" : { "AutoScalingReplacingUpdate" : { "WillReplace" : true } }, "CreationPolicy" : { "ResourceSignal" : { "Count" : { "Ref" : "ResourceSignalsOnCreate"}, "Timeout" : "PT10M" }, "AutoScalingCreationPolicy" : { "MinSuccessfulInstancesPercent" : { "Ref" : "MinSuccessfulPercentParameter" } } }
YAML
UpdatePolicy: AutoScalingReplacingUpdate: WillReplace: true CreationPolicy: ResourceSignal: Count: !Ref 'ResourceSignalsOnCreate' Timeout: PT10M AutoScalingCreationPolicy: MinSuccessfulInstancesPercent: !Ref 'MinSuccessfulPercentParameter'
Disponibilità durante l'aggiornamento dei metadati per lo script helper cfn-init
Quando installi applicazioni software sulle tue istanze, puoi usare il AWS::CloudFormation::Initchiave per i metadati e cfn-initscript di supporto per avviare le istanze nel gruppo Auto Scaling. CloudFormation installa i pacchetti, esegue i comandi ed esegue altre azioni di bootstrap descritte nei metadati.
Quando si aggiornano solo i metadati (ad esempio, quando si aggiorna un pacchetto a un'altra versione), è possibile utilizzare il cfn-hupdemone helper per rilevare e applicare gli aggiornamenti. Tuttavia, il daemon cfn-hup
viene eseguito in modo indipendente su ciascuna istanza. Se il daemon viene eseguito contemporaneamente su tutte le istanze, l'applicazione o il servizio potrebbe non essere disponibile durante l'aggiornamento. Per garantire la disponibilità, puoi forzare un aggiornamento periodico in modo che CloudFormation aggiorni le istanze un batch alla volta.
Importante
Per forzare un aggiornamento continuo CloudFormation è necessario creare una nuova istanza e quindi eliminare quella precedente. Le informazioni memorizzate nell'istanza precedente andranno perse.
Per forzare un aggiornamento continuo, modifica l'ID logico della risorsa di configurazione di avvio, quindi aggiorna lo stack e tutti i riferimenti che puntano all'ID logico originale (come il gruppo Auto Scaling associato). CloudFormation attiva un aggiornamento continuo nel gruppo Auto Scaling, sostituendo tutte le istanze.
Modello originale
"LaunchConfig": { "Type" : "AWS::AutoScaling::LaunchConfiguration", "Metadata" : { "Comment" : "Install a simple PHP application", "AWS::CloudFormation::Init" : { ... } } }
ID logico aggiornato
"LaunchConfigUpdateRubygemsPkg": { "Type" : "AWS::AutoScaling::LaunchConfiguration", "Metadata" : { "Comment" : "Install a simple PHP application", "AWS::CloudFormation::Init" : { ... } } }
Policy di aggiornamento dell'alias Lambda
Nell'esempio seguente viene specificato l'attributo UpdatePolicy
per una risorsa AWS::Lambda::Alias
. Tutti i dettagli per la distribuzione sono definiti dall'applicazione e dal gruppo di distribuzione trasferiti nella policy.
JSON
"Alias": { "Type": "AWS::Lambda::Alias", "Properties": { "FunctionName": { "Ref": "LambdaFunction" }, "FunctionVersion": { "Fn::GetAtt": [ "FunctionVersionTwo", "Version" ] }, "Name": "MyAlias" }, "UpdatePolicy": { "CodeDeployLambdaAliasUpdate": { "ApplicationName": { "Ref": "CodeDeployApplication" }, "DeploymentGroupName": { "Ref": "CodeDeployDeploymentGroup" }, "BeforeAllowTrafficHook": { "Ref": "PreHookLambdaFunction" }, "AfterAllowTrafficHook": { "Ref": "PreHookLambdaFunction" } } } }
YAML
Alias: Type: 'AWS::Lambda::Alias' Properties: FunctionName: !Ref LambdaFunction FunctionVersion: !GetAtt FunctionVersionTwo.Version Name: MyAlias UpdatePolicy: CodeDeployLambdaAliasUpdate: ApplicationName: !Ref CodeDeployApplication DeploymentGroupName: !Ref CodeDeployDeploymentGroup BeforeAllowTrafficHook: !Ref PreHookLambdaFunction AfterAllowTrafficHook: !Ref PreHookLambdaFunction