Migrazione basata su canary all'autorità di certificazione Cloud Service Mesh
La migrazione all'autorità di certificazione Cloud Service Mesh (Cloud Service Mesh CA) da Istio CA (nota anche come Citadel) richiede la migrazione del root of trust. Prima di Cloud Service Mesh 1.10, se volevi eseguire la migrazione da Istio su Google Kubernetes Engine (GKE) a Cloud Service Mesh con l'autorità di certificazione Cloud Service Mesh, dovevi pianificare il tempo di riposo perché Cloud Service Mesh non era in grado di caricare più certificati principali. Pertanto, durante la migrazione, i carichi di lavoro appena di cui è stato eseguito il deployment si basano sul nuovo certificato radice, mentre altri si basano sul vecchio certificato radice. I carichi di lavoro che utilizzano certificati firmati da certificati radice diversi non possono autenticarsi tra loro. Ciò significa che il traffico TLS (mTLS) reciproco viene interrotto durante la migrazione. L'intero cluster si riprende completamente solo quando il piano di controllo e tutti i carichi di lavoro in tutti gli spazi dei nomi vengono nuovamente implementati con il certificato dell'autorità di certificazione di Cloud Service Mesh. Se il tuo mesh ha più cluster con carichi di lavoro che inviano richieste a carichi di lavoro su un altro cluster, devono essere aggiornati anche tutti i carichi di lavoro su questi cluster.
Segui i passaggi descritti in questa guida per i seguenti casi d'uso:
- Esegui la migrazione da Istio on GKE al piano di controllo interno al cluster di Cloud Service Mesh 1.19.10-asm.9 con l'autorità di certificazione Cloud Service Mesh.
- Esegui l'upgrade da Cloud Service Mesh 1.15 o una release con patch 1.16 con CA Istio al control plane in-cluster di Cloud Service Mesh 1.19.10-asm.9 con l'autorità di certificazione Cloud Service Mesh.
Limitazioni
- Tutti i cluster GKE devono trovarsi nello stesso progetto Google Cloud .
Prerequisiti
Segui i passaggi descritti in Installare gli strumenti dipendenti e convalidare il cluster per:- Installare gli strumenti richiesti
- Scarica
asmcli
- Concedere le autorizzazioni di amministratore del cluster
- Convalidare il progetto e il cluster
Strumenti richiesti
Durante la migrazione, esegui uno strumento fornito da Google, migrate_ca
, per verificare quanto segue per ogni pod del cluster:
- Il certificato radice per l'autorità di certificazione Istio CA e Cloud Service Mesh.
- Il certificato mTLS del carico di lavoro emesso dall'autorità di certificazione Istio e dall'autorità di certificazione Cloud Service Mesh.
- I domini attendibili configurati dall'autorità di certificazione Istio CA e Cloud Service Mesh.
Questo strumento ha le seguenti dipendenze:
awk
grep
istioctl
L'esecuzione diasmcli install
scarica la versione diistioctl
corrispondente alla versione di Cloud Service Mesh che stai installando.jq
kubectl
openssl
Panoramica della migrazione
Per eseguire la migrazione all'autorità di certificazione Cloud Service Mesh, segui la procedura di migrazione basata sulle revisioni (chiamata anche "upgrade canary"). Con una migrazione basata su revisioni, viene implementata una nuova revisione del piano di controllo insieme a quella esistente. Poi, muovi gradualmente i carichi di lavoro alla nuova revisione, il che ti consente di monitorare l'effetto della migrazione durante la procedura. Durante il processo di migrazione, l'autenticazione e l'autorizzazione sono completamente funzionali tra i carichi di lavoro che utilizzano l'autorità di certificazione Cloud Service Mesh e i carichi di lavoro che utilizzano la CA Istio.
Di seguito è riportata una panoramica della migrazione all'autorità di certificazione Cloud Service Mesh:
Distribuisci la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh.
Installa una nuova revisione del piano di controllo che utilizza la CA Istio con un'opzione che distribuirà la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh.
Esegui la migrazione dei carichi di lavoro al nuovo piano di controllo, uno spazio dei nomi alla volta, e testa la tua applicazione. Una volta eseguita la migrazione di tutti i workload al nuovo piano di controllo, rimuovi il vecchio piano di controllo.
Esegui la migrazione all'autorità di certificazione Cloud Service Mesh. Ora che tutti i proxy sidecar sono configurati con la vecchia radice di attendibilità e la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh, puoi eseguire la migrazione all'autorità di certificazione Cloud Service Mesh senza tempi di riposo. Anche in questo caso, segui la procedura di migrazione basata sulle revisioni:
Installa una revisione del piano di controllo con l'autorità di certificazione Cloud Service Mesh abilitata.
Esegui la migrazione dei carichi di lavoro alla nuova revisione del piano di controllo, uno spazio dei nomi alla volta, e testa l'applicazione. Una volta eseguita la migrazione di tutti i workload al nuovo piano di controllo, rimuovi il vecchio piano di controllo.
Rimuovi i secret della CA nel cluster associati alla vecchia CA e riavvia il nuovo piano di controllo.
Distribuisci la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh
Prima di poter eseguire la migrazione all'autorità di certificazione Cloud Service Mesh, tutti i cluster GKE nel mesh devono avere Cloud Service Mesh 1.10 o versioni successive e tutti i cluster devono essere configurati con un'opzione del piano di controllo che attivi la radice di attendibilità per l'autorità di certificazione Cloud Service Mesh da distribuire ai proxy di tutti i carichi di lavoro sul cluster. Al termine del processo, ogni proxy è configurato sia con la vecchia sia con la nuova radice della attendibilità. Con questo schema, quando esegui la migrazione all'autorità di certificazione Cloud Service Mesh, i carichi di lavoro che la utilizzano potranno autenticarsi con i carichi di lavoro che utilizzano la vecchia CA.
Installa una nuova revisione del piano di controllo
Installa una revisione del piano di controllo con un'opzione che distribuisce la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh.
Segui i passaggi descritti in Installare gli strumenti dipendenti e convalidare il cluster per prepararti a utilizzare uno strumento fornito da Google,
asmcli
, per installare la nuova revisione del piano di controllo.Assicurati di avere la versione di
asmcli
che installa Cloud Service Mesh 1.11 o versioni successive:./asmcli --version
Esegui
asmcli install
. Nel seguente comando, sostituisci i segnaposto con i tuoi valori../asmcli install \ --fleet_id FLEET_PROJECT_ID \ --kubeconfig KUBECONFIG_FILE \ --enable_all \ --ca citadel \ --ca_cert CA_CERT_FILE_PATH \ --ca_key CA_KEY_FILE_PATH \ --root_cert ROOT_CERT_FILE_PATH \ --cert_chain CERT_CHAIN_FILE_PATH \ --option ca-migration-citadel \ --revision_name REVISION_1 \ --output_dir DIR_PATH
--fleet_id
L'ID del progetto host del parco risorse.--kubeconfig
Il percorso del filekubeconfig
Puoi specificare un percorso relativo o un percorso completo. La variabile di ambiente$PWD
non funziona qui.--output_dir
Includi questa opzione per specificare una directory in cuiasmcli
scarica il pacchettoanthos-service-mesh
ed estrae il file di installazione, che contieneistioctl
, i sample e i manifest. In caso contrario,asmcli
scarica i file in una directorytmp
. Puoi specificare un percorso relativo o un percorso completo. La variabile di ambiente$PWD
non funziona qui.-
--enable_all
Consente allo strumento di:- Concedi le autorizzazioni IAM richieste.
- Abilita le API Google richieste.
- Imposta un'etichetta sul cluster che identifichi il mesh.
- Registra il cluster nel parco risorse, se non è già registrato.
-ca citadel
Per evitare tempi di riposo, specifica la CA Istio (l'opzione "citadel" corrisponde alla CA Istio). A questo punto, non passare alla CA Cloud Service Mesh.--ca_cert
Il certificato intermedio.--ca_key
La chiave del certificato intermedio--root_cert
Il certificato radice.--cert_chain
La catena di certificati.--option ca-migration-citadel
Quando esegui il ricollocamento dei workload, questa opzione attiva la distribuzione della nuova radice di attendibilità ai proxy sidecar dei workload.REVISION_1
: consigliato. Un [Etichetta di revisione](/service-mesh/docs/revisions-overview) è una coppia chiave-valore impostata nel piano di controllo. La chiave dell'etichetta di revisione è sempreistio.io/rev
. Per impostazione predefinita, lo strumento imposta il valore per l'etichetta della revisione in base alla versione di Cloud Service Mesh, ad esempio:asm-11910-9
. Ti consigliamo di includere questa opzione e di sostituireREVISION_1
con un nome che descriva l'installazione, ad esempioasm-11910-9-distribute-root
. Il nome deve essere un'etichetta DNS-1035 e deve essere costituito da caratteri alfanumerici in minuscolo o-
, deve iniziare con un carattere alfabetico e terminare con un carattere alfanumerico (ad esempiomy-name
oabc-123
).
Esegui la migrazione dei carichi di lavoro al nuovo control plane
Per completare la distribuzione della nuova radice di attendibilità, devi etichettare i tuoi spazi dei nomi con l'etichetta di revisioneistio.io/rev=<var>REVISION_1</var>-distribute-root
e riavviare i carichi di lavoro. Quando testi i carichi di lavoro dopo averli riavviati, esegui uno strumento per verificare che il proxy sidecar sia configurato sia con la radice precedente sia con quella nuova della radice di attendibilità per l'autorità di certificazione Cloud Service Mesh.
Imposta il contesto corrente per
kubectl
. Nel seguente comando, sostituisci--region
con--zone
se hai un cluster a zona singola.gcloud container clusters get-credentials CLUSTER_NAME \ --project=PROJECT_ID \ --region=CLUSTER_LOCATION
Scarica lo strumento di convalida:
curl https://raw.githubusercontent.com/GoogleCloudPlatform/anthos-service-mesh-packages/master/scripts/ca-migration/migrate_ca > migrate_ca
Imposta il bit eseguibile sullo strumento:
chmod +x migrate_ca
Lo strumento
migrate_ca
chiamaistioctl
, che dipende dalla versione. Lo strumentoasmcli
aggiunge un link simbolico aistioctl
nella directory specificata per--output_dir
. Assicurati che la directory sia all'inizio del percorso. Nel comando seguente, sostituisciISTIOCTL_PATH
con la directory contenenteistioctl
scaricata dallo strumento.export PATH=ISTIOCTL_PATH:$PATH which istioctl echo $PATH
Recupera l'etichetta di revisione su
istiod
eistio-ingressgateway
.kubectl get pod -n istio-system -L istio.io/rev
L'output è simile al seguente:
NAME READY STATUS RESTARTS AGE REV istio-ingressgateway-5fd454f8ff-t7w9x 1/1 Running 0 36m default istio-ingressgateway-asm-195-2-distribute-root-c6ccfbdbd-z2s9p 1/1 Running 0 18m asm-195-2-distribute-root istio-ingressgateway-asm-195-2-distribute-root-c6ccfbdbd-zr2cs 1/1 Running 0 18m asm-195-2-distribute-root istiod-68bc495f77-shl2h 1/1 Running 0 36m default istiod-asm-195-2-distribute-root-6f764dbb7c-g9f8c 1/1 Running 0 18m asm-195-2-distribute-root istiod-asm-195-2-distribute-root-6f764dbb7c-z7z9s 1/1 Running 0 18m asm-195-2-distribute-root
Nell'output, nella colonna
REV
, prendi nota del valore dell'etichetta della revisione per la nuova revisione, che corrisponde all'etichetta della revisione specificata quando hai eseguitoasmcli install
. In questo esempio, il valore èasm-11910-9-distribute-root
.Devi eliminare la vecchia revisione di
istiod
al termine del trasferimento dei carichi di lavoro alla nuova revisione. Prendi nota del valore nell'etichetta della revisione per la revisioneistiod
precedente. L'output di esempio mostra una migrazione da Istio, che utilizza la revisionedefault
.
Aggiungi l'etichetta di revisione a uno spazio dei nomi e rimuovi l'etichetta
istio-injection
(se esistente). Nel comando seguente, sostituisciNAMESPACE
con lo spazio dei nomi da etichettare.kubectl label namespace NAMESPACE istio.io/rev=REVISION_1 istio-injection- --overwrite
Se nell'output viene visualizzato
"istio-injection not found"
, puoi ignorarlo. Ciò significa che lo spazio dei nomi non aveva precedentemente l'etichettaistio-injection
. Poiché il comportamento di inserimento automatico è undefined quando uno spazio dei nomi ha sia l'etichettaistio-injection
sia l'etichetta revision, tutti i comandikubectl label
nella documentazione di Cloud Service Mesh garantiscono esplicitamente che ne sia impostato solo uno.Riavvia i pod per attivare la re-iniezione.
kubectl rollout restart deployment -n NAMESPACE
Testa l'applicazione per verificare che i carichi di lavoro funzionino correttamente.
Se hai carichi di lavoro in altri spazi dei nomi, ripeti i passaggi per etichettare lo spazio dei nomi e riavviare i pod.
Verifica che i proxy sidecar per tutti i workload del cluster siano configurati sia con i certificati principali vecchi che con quelli nuovi:
./migrate_ca check-root-cert
Risultato previsto:
Namespace: foo httpbin-66cdbdb6c5-pmzps.foo trusts [CITADEL MESHCA] sleep-64d7d56698-6tmjm.foo trusts [CITADEL MESHCA]
Se devi eseguire la migrazione dei gateway, segui i passaggi descritti in Upgrade Canary (avanzato) per installare i nuovi deployment dei gateway. Tieni presente quanto segue:
- Utilizza
REVISION_1
come etichetta della revisione. - Esegui il deployment delle risorse del gateway nello stesso spazio dei nomi del gateway dell'installazione precedente per eseguire la migrazione senza tempi di riposo. Assicurati che le risorse di servizio che rimandano al gateway precedente includano ora anche le implementazioni più recenti.
- Non eliminare i deployment del gateway precedenti finché non avrai la certezza che la tua applicazione funzioni correttamente (dopo il passaggio successivo).
- Utilizza
Se ritieni che la tua applicazione funzioni come previsto, continua con i passaggi per la transizione alla nuova versione di
istiod
. Se si verifica un problema con l'applicazione, segui i passaggi per il rollback.Completare la transizione
Se ritieni che la tua applicazione funzioni come previsto, rimuovi il vecchio piano di controllo per completare la transizione alla nuova versione.
Vai alla directory in cui si trovano i file del
anthos-service-mesh
repository GitHub.Configura il webhook di convalida in modo che utilizzi il nuovo piano di controllo.
kubectl apply -f asm/istio/istiod-service.yaml
Elimina il vecchio
istio-ingressgateway
deployment. Il comando eseguito dipende dal fatto che tu stia eseguendo la migrazione da Istio o l'upgrade da una versione precedente di Cloud Service Mesh:Esegui la migrazione
Se hai eseguito la migrazione da Istio, il vecchio
istio-ingressgateway
non ha un'etichetta di revisione.kubectl delete deploy/istio-ingressgateway -n istio-system
Esegui l'upgrade
Se hai eseguito l'upgrade da una versione precedente di Cloud Service Mesh, nel comando seguente, sostituisci
OLD_REVISION
con l'etichetta della revisione per la versione precedente delistio-ingressgateway
.kubectl delete deploy -l app=istio-ingressgateway,istio.io/rev=OLD_REVISION -n istio-system --ignore-not-found=true
Elimina la vecchia revisione di
istiod
. Il comando che utilizzi dipende se esegui la migrazione da Istio o l'upgrade da una versione precedente di Cloud Service Mesh.Esegui la migrazione
Se hai eseguito la migrazione da Istio, il vecchio
istio-ingressgateway
non ha un'etichetta di revisione.kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod -n istio-system --ignore-not-found=true
Esegui l'upgrade
Se hai eseguito l'upgrade da una versione precedente di Cloud Service Mesh, nel comando seguente assicurati che
OLD_REVISION
corrisponda all'etichetta di revisione della versione precedente diistiod
.kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod-OLD_REVISION -n istio-system --ignore-not-found=true
Rimuovi la versione precedente della configurazione
IstioOperator
.kubectl delete IstioOperator installed-state-OLD_REVISION -n istio-system
L'output previsto è simile al seguente:
istiooperator.install.istio.io "installed-state-OLD_REVISION" deleted
Esegui il rollback
Se hai riscontrato un problema durante il test dell'applicazione con la nuova versione di
istiod
, segui questi passaggi per eseguire il rollback alla versione precedente:Elimina i nuovi deployment del gateway installati nel passaggio 11.
Rinomina lo spazio dei nomi per attivare l'iniezione automatica con la versione precedente di
istiod
. Il comando che utilizzi dipende dal fatto che tu abbia usato un'etichetta di revisione oistio-injection=enabled
con la versione precedente.Se hai utilizzato un'etichetta di revisione per l'iniezione automatica:
kubectl label namespace NAMESPACE istio.io/rev=OLD_REVISION --overwrite
Se hai utilizzato
istio-injection=enabled
:kubectl label namespace NAMESPACE istio.io/rev- istio-injection=enabled --overwrite
Risultato previsto:
namespace/NAMESPACE labeled
Verifica che l'etichetta di revisione nello spazio dei nomi corrisponda all'etichetta di revisione della versione precedente di
istiod
:kubectl get ns NAMESPACE --show-labels
Riavvia i pod per attivare la re-iniezione in modo che i proxy abbiano la versione precedente:
kubectl rollout restart deployment -n NAMESPACE
Rimuovi il nuovo deployment
istio-ingressgateway
.kubectl delete deploy -l app=istio-ingressgateway,istio.io/rev=REVISION_1 -n istio-system --ignore-not-found=true
Rimuovi la nuova revisione di
istiod
.kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod-REVISION_1 -n istio-system --ignore-not-found=true
Rimuovi la nuova configurazione di
IstioOperator
.kubectl delete IstioOperator installed-state-asm-11910-9-distribute-root -n istio-system
L'output previsto è simile al seguente:
istiooperator.install.istio.io "installed-state-asm-11910-9-distribute-root" deleted
Esegui la migrazione all'autorità di certificazione Cloud Service Mesh
Ora che i proxy sidecar per tutti i carichi di lavoro sono configurati sia con la vecchia radice di attendibilità sia con la nuova radice di attendibilità per l'autorità di certificazione Cloud Service Mesh, i passaggi per eseguire la migrazione all'autorità di certificazione Cloud Service Mesh sono simili a quelli che hai eseguito per distribuire la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh:
Installa un nuovo piano di controllo con l'autorità di certificazione Cloud Service Mesh abilitata
Utilizzi asmcli install
per installare una nuova revisione del piano di controllo con la CA Mesh attivata.
Se hai personalizzato l'installazione precedente, devi specificare gli stessi file di overlay quando esegui
asmcli install
.Esegui
asmcli install
. Nel comando seguente, sostituisci i segnaposto con i tuoi valori../asmcli install \ --fleet_id FLEET_PROJECT_ID \ --kubeconfig KUBECONFIG_FILE \ --output_dir DIR_PATH \ --enable_all \ --ca mesh_ca \ --root_cert ROOT_CERT_FILE_PATH \ --cert_chain CERT_CHAIN_FILE_PATH --option ca-migration-meshca \ --revision_name REVISION_2 \ --output_dir DIR_PATH \ OVERLAYS
--fleet_id
L'ID del progetto host del parco risorse.--kubeconfig
Il percorso delkubeconfig
file Puoi specificare un percorso relativo o un percorso completo. La variabile di ambiente$PWD
non funziona qui.--output_dir
Includi questa opzione per specificare una directory doveasmcli
scarica il pacchettoanthos-service-mesh
ed estrae il file di installazione, che contieneistioctl
, i sample e i manifest. In caso contrario,asmcli
scarica i file in una directorytmp
. Puoi specificare un percorso relativo o un percorso completo. La variabile di ambiente$PWD
non funziona qui.-
--enable_all
Consente allo strumento di:- Concedi le autorizzazioni IAM richieste.
- Abilita le API Google richieste.
- Imposta un'etichetta sul cluster che identifichi il mesh.
- Registra il cluster nel parco risorse, se non è già registrato.
--ca mesh_ca
Ora puoi passare all'autorità di certificazione Cloud Service Mesh poiché è stata distribuita la radice di attendibilità dell'autorità di certificazione Cloud Service Mesh.REVISION_2
Consigliata. SostituisciREVISION_2
con un nome che descriva l'installazione, ad esempioasm-11910-9-meshca-ca-migration
. Il nome deve essere un'etichetta DNS-1035 e deve essere costituito da caratteri alfanumerici in minuscolo o-
, deve iniziare con un carattere alfabetico e terminare con un carattere alfanumerico (ad esempiomy-name
oabc-123
).--option ca-migration-migration
Quando [riesegui il deployment dei carichi di lavoro](/service-mesh/docs/unified-install/install-anthos-service-mesh#deploy_and_redeploy_workloads), questa opzione configura i proxy in modo che utilizzino l'autorità di certificazione radice di attendibilità di Cloud Service Mesh.
Esegui la migrazione dei carichi di lavoro al nuovo control plane
Per completare l'installazione, devi etichettare gli spazi dei nomi con la nuova etichetta di revisione e riavviare i carichi di lavoro.
Recupera l'etichetta di revisione su
istiod
eistio-ingressgateway
.kubectl get pod -n istio-system -L istio.io/rev
L'output è simile al seguente:
NAME READY STATUS RESTARTS AGE REV istio-ingressgateway-asm-11910-9-distribute-root-65d884685d-6hrdk 1/1 Running 0 67m asm-11910-9-distribute-root istio-ingressgateway-asm-11910-9-distribute-root65d884685d-94wgz 1/1 Running 0 67m asm-11910-9-distribute-root istio-ingressgateway-asm-11910-9-meshca-ca-migration-8b5fc8767-gk6hb 1/1 Running 0 5s asm-11910-9-meshca-ca-migration istio-ingressgateway-asm-11910-9-meshca-ca-migration-8b5fc8767-hn4w2 1/1 Running 0 20s asm-11910-9-meshca-ca-migration istiod-asm-11910-9-distribute-root-67998f4b55-lrzpz 1/1 Running 0 68m asm-11910-9-distribute-root istiod-asm-11910-9-distribute-root-67998f4b55-r76kr 1/1 Running 0 68m asm-11910-9-distribute-root istiod-asm-11910-9-meshca-ca-migration-5cd96f88f6-n7tj9 1/1 Running 0 27s asm-11910-9-meshca-ca-migration istiod-asm-11910-9-meshca-ca-migration-5cd96f88f6-wm68b 1/1 Running 0 27s asm-11910-9-meshca-ca-migration
Nell'output, nella colonna
REV
, prendi nota del valore dell'etichetta della revisione per la nuova versione. In questo esempio, il valore èasm-11910-9-meshca-ca-migration
.Prendi nota anche del valore nell'etichetta della revisione per la versione
istiod
precedente. Ti serve per eliminare la versione precedente diistiod
al termine del trasferimento dei carichi di lavoro alla nuova versione. Nell'esempio, il valore dell'etichetta della revisione per la revisione precedente èasm-11910-9-distribute-root
.
Aggiungi la nuova etichetta di revisione a uno spazio dei nomi. Nel seguente comando, sostituire
NAMESPACE
con lo spazio dei nomi da etichettare.kubectl label namespace NAMESPACE istio.io/rev=REVISION_2 --overwrite
Riavvia i pod per attivare la re-iniezione.
kubectl rollout restart deployment -n NAMESPACE
Testa l'applicazione per verificare che i carichi di lavoro funzionino correttamente. Assicurati che la comunicazione mTLS funzioni tra i carichi di lavoro nello spazio dei nomi precedente e quelli nello spazio dei nomi più recente.
Se hai carichi di lavoro in altri spazi dei nomi, ripeti i passaggi per etichettare lo spazio dei nomi e riavviare i pod.
Segui i passaggi descritti in Upgrade in situ per eseguire l'upgrade delle implementazioni precedenti del gateway installate nel passaggio 11 della sezione precedente alla revisione più recente
REVISION_2
.Se ritieni che la tua applicazione funzioni come previsto, continua con i passaggi per la transizione al nuovo piano di controllo. Se si verifica un problema con l'applicazione, segui i passaggi per il rollback.
Completare la transizione
Se ritieni che la tua applicazione funzioni come previsto, rimuovi il vecchio piano di controllo per completare la transizione alla nuova versione.
Vai alla directory in cui si trovano i file del
anthos-service-mesh
repository GitHub.Configura il webhook di convalida in modo che utilizzi il nuovo piano di controllo.
kubectl apply -f asm/istio/istiod-service.yaml
Elimina il vecchio
istio-ingressgateway
deployment. Nel seguente comando, sostituisciOLD_REVISION
con l'etichetta della revisione per la versione precedente diistio-ingressgateway
.kubectl delete deploy -l app=istio-ingressgateway,istio.io/rev=OLD_REVISION -n istio-system --ignore-not-found=true
Elimina la vecchia revisione
istiod
. Nel comando seguente, sostituisciOLD_REVISION
con l'etichetta di revisione della versione precedente diistiod
.kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod-OLD_REVISION -n istio-system --ignore-not-found=true
Rimuovi la vecchia configurazione di
IstioOperator
.kubectl delete IstioOperator installed-state-OLD_REVISION -n istio-system
L'output previsto è simile al seguente:
istiooperator.install.istio.io "installed-state-OLD_REVISION" deleted
Esegui il rollback
Se hai riscontrato un problema durante il test dell'applicazione con la nuova revisione
istiod
, segui questi passaggi per eseguire il rollback alla revisione precedente:Segui i passaggi descritti nella sezione Upgrade in situ per eseguire il downgrade dei deployment dei gateway di cui è stato eseguito l'upgrade in precedenza nel passaggio 6 di questa sezione alla revisione precedente
REVISION_1
.Rinomina lo spazio dei nomi per attivare l'iniezione automatica con la revisione
istiod
precedente.kubectl label namespace NAMESPACE istio.io/rev=OLD_REVISION --overwrite
Risultato previsto:
namespace/NAMESPACE labeled
Verifica che l'etichetta di revisione nello spazio dei nomi corrisponda all'etichetta di revisione della versione precedente di
istiod
:kubectl get ns NAMESPACE --show-labels
Riavvia i pod per attivare la re-iniezione in modo che i proxy abbiano la versione precedente:
kubectl rollout restart deployment -n NAMESPACE
Rimuovi il nuovo deployment
istio-ingressgateway
.kubectl delete deploy -l app=istio-ingressgateway,istio.io/rev=REVISION_2 -n istio-system --ignore-not-found=true
Rimuovi la nuova versione di
istiod
. Assicurati che l'etichetta della revisione nel seguente comando corrisponda alla tua revisione.kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod-REVISION_2 -n istio-system --ignore-not-found=true
Rimuovi la nuova versione della configurazione
IstioOperator
.kubectl delete IstioOperator installed-state-REVISION_2 -n istio-system
L'output previsto è simile al seguente:
istiooperator.install.istio.io "installed-state-REVISION_2" deleted
Rimuovi i secret della CA e riavvia il nuovo piano di controllo
Conserva i secret per utilizzarli in caso di necessità:
kubectl get secret/cacerts -n istio-system -o yaml > save_file_1 kubectl get secret/istio-ca-secret -n istio-system -o yaml > save_file_2
Rimuovi i secret della CA nel cluster associato alla vecchia CA:
kubectl delete secret cacerts istio-ca-secret -n istio-system --ignore-not-found
Riavvia il control plane appena installato. In questo modo, la vecchia radice della cooperazione viene eliminata da tutti i carichi di lavoro in esecuzione nel mesh.
kubectl rollout restart deployment -n istio-system