Riduzione dei rischi con deployment blu/verde

Questa pagina mostra come eseguire il deployment di una nuova versione dell'applicazione e come migrare il traffico da una versione precedente a una nuova.

Esegui il push dell'app iniziale

Utilizza l'interfaccia a riga di comando Kf per eseguire il push della versione iniziale dell'app con qualsiasi route:

$ kf push app-v1 --route my-app.my-space.example.com

Esegui il push dell'app aggiornata

Utilizza l'interfaccia a riga di comando Kf per eseguire il push di una nuova versione dell'app senza route:

$ kf push app-v2 --no-route

Aggiungi percorsi all'app aggiornata

Utilizza l'interfaccia a riga di comando Kf per associare tutte le route esistenti all'app aggiornata con un peso pari a 0 per assicurarti che non ricevano alcuna richiesta:

$ kf map-route app-v2 my-space.example.com --hostname my-app --weight 0

Shift il traffico

Inizia a spostare il traffico dall'app precedente a quella aggiornata aggiornando le ponderazioni sui percorsi:

$ kf map-route app-v1 my-space.example.com --hostname my-app --weight 80
$ kf map-route app-v2 my-space.example.com --hostname my-app --weight 20

Se il deployment va bene, puoi spostare più traffico aggiornando di nuovo le ponderazioni:

$ kf map-route app-v1 my-space.example.com --hostname my-app --weight 50
$ kf map-route app-v2 my-space.example.com --hostname my-app --weight 50

Completa lo spostamento del traffico

Dopo aver verificato che il nuovo servizio non abbia introdotto regressioni, completa l'implementazione spostando tutto il traffico nella nuova istanza:

$ kf map-route app-v1 my-space.example.com --hostname my-app --weight 0
$ kf map-route app-v2 my-space.example.com --hostname my-app --weight 100

Abbassa l'app originale

Quando ritieni che non siano necessari rollback rapidi, rimuovi il percorso originale e interrompi l'app:

$ kf unmap-route app-v1 myspace.example.com --hostname my-app
$ kf stop app-v1

In alternativa, elimina l'app e tutte le mappature delle route associate:

$ kf delete app-v1