Attributo UpdatePolicy - AWS CloudFormation

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'UpdatePolicyattributo per specificare come AWS CloudFormation gestisce gli aggiornamenti di determinate risorse durante le operazioni di aggiornamento dello stack.

Panoramica

Utilizzando l'UpdatePolicyattributo, è 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:

    • AutoScalingReplacingUpdatee AutoScalingRollingUpdate politiche: CloudFormation possono sostituire il gruppo Auto Scaling e le relative istanze con una AutoScalingReplacingUpdate 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 e AutoScalingRollingUpdate, l'impostazione della proprietà WillReplace su true da la precedenza a AutoScalingReplacingUpdate.

    • AutoScalingScheduledActionpolitica: 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'UpdatePolicyattributo 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 dalla MinSuccessfulInstancesPercent proprietà) non segnala l'esito positivo entro il Timeout periodo specificato nella CreationPolicy 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 valore MaxBatchSize 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 modifiche UpdatePolicy 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 CloudFormation stack?

  • 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 un CONTINUE 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 raggiunge InService 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 } }

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 una InService percentuale minima di 50, almeno tre istanze devono trovarsi nello stato. InService Se un'istanza non passa allo InService stato entro un periodo prestabilito di 1 ora, si CloudFormation presuppone che l'istanza non sia stata aggiornata.

L'impostazione MinActiveInstancesPercent su UpdatePolicy influirà anche sulle istanze avviate quando la DesiredCapacity proprietà della AWS::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 nella PauseTime 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 la MinSuccessfulInstancesPercent proprietà è impostata su 0, CloudFormation attende che lo 0% delle istanze di capacità si trovi in uno InService stato. MinSuccessfulInstancesPercentritorna immediatamente e prima di considerare lo stato del gruppo Auto Scaling UPDATE_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 stato InService, 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 formatoPT#H#M#S, dove ciascuno # corrisponde rispettivamente al numero di ore, minuti e secondi). Il valore massimo di PauseTime è 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 Se PauseTime 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, un PauseTime breve può comprometterne la riuscita.

Impostazione predefinita: PT5M (5 minuti) quando la WaitOnResourceSignals 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à, la WaitOnResourceSignals proprietà deve essere impostata su. true

Policy AutoScalingScheduledAction

Per specificare in che modo CloudFormation gestisce gli aggiornamenti per MinSizeMaxSize, 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à MinSizeMaxSize, o a meno che tu non abbia modificato questi valori nel tuo modello.

Sintassi

JSON

"UpdatePolicy" : { "AutoScalingScheduledAction" : { "IgnoreUnmodifiedGroupSizeProperties" : Boolean } }

Proprietà

IgnoreUnmodifiedGroupSizeProperties

Iftrue, 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 aggiornamento AWS::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 e NodeGroupConfiguration 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 e ReplicaCount per ciascun NodeGroupConfiguration . 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 ciascuna NodeGroupConfiguration 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 } }

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: !Ref logicalName Version: !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

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