Riduzione dei rischi con deployment blu/verde

Questa pagina mostra come eseguire il deployment di una nuova versione dell'applicazione ed eseguire la migrazione il traffico da una vecchia versione a una nuova.

Esegui il push dell'app iniziale

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

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

Invia l'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

Aggiungere le route all'app aggiornata

Utilizza l'interfaccia a riga di comando Kf per associare tutte le route esistenti all'oggetto App con ponderazione pari a 0 per garantire che non riceva alcuna richiesta:

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

Shift il traffico

Inizia a spostare il traffico dalla vecchia app a quella aggiornata aggiornando i pesi sulle route:

$ 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 procede correttamente, puoi spostare altro traffico aggiornando di nuovo i pesi:

$ 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

Una volta accertato che il nuovo servizio non ha 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

Disattiva l'app originale

Quando ritieni che i rollback rapidi non siano necessari, rimuovi l'originale percorso 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 dei percorsi associate:

$ kf delete app-v1