Inserisci proxy sidecar con Anthos Service Mesh

Questo documento illustra come configurare l'inserimento di proxy sidecar con Anthos Service Mesh per migliorare la sicurezza, l'affidabilità e l'osservabilità della rete. Queste funzioni sono astratte dal container principale dell'applicazione e implementate in un proxy out-of-process comune (il file collaterale), consegnato come container separato nello stesso pod. Questo fornisce le funzionalità di Anthos Service Mesh senza riprogettare le applicazioni di produzione per partecipare a un mesh di servizi.

L'inserimento automatico di proxy sidecar (inserimento automatica) si verifica quando Anthos Service Mesh rileva un'etichetta dello spazio dei nomi configurata per il pod del carico di lavoro. Il proxy intercetta tutto il traffico in entrata e in uscita verso i carichi di lavoro e comunica con Anthos Service Mesh.

Abilitazione dell'inserimento automatico di sidecar

Il modo consigliato per inserire proxy sidecar è utilizzare l'iniettore automatico basato su webhook, anche se puoi aggiornare manualmente la configurazione Kubernetes dei tuoi pod.

Per abilitare l'inserimento automatico, etichetta gli spazi dei nomi con le etichette di iniezione predefinite se è configurato il tag predefinito o con l'etichetta di revisione nello spazio dei nomi. L'etichetta che aggiungi dipende anche dal fatto che tu abbia eseguito il deployment di Anthos Service Mesh gestito (con l'API del parco risorse o con asmcli) o che hai installato il piano di controllo nel cluster. L'etichetta viene utilizzata dal webhook iniettore sidecar per associare i sidecar inseriti a una determinata revisione del piano di controllo.

Per abilitare l'inserimento automatico:

Nel cluster

  1. Usa il seguente comando per individuare l'etichetta della revisione su istiod:

    kubectl -n istio-system get pods -l app=istiod --show-labels
    

    L'output è simile al seguente:

    NAME                                READY   STATUS    RESTARTS   AGE   LABELS
    istiod-asm-1182-4-5788d57586-bljj4   1/1     Running   0          23h   app=istiod,istio.io/rev=asm-1182-4,istio=istiod,pod-template-hash=5788d57586
    istiod-asm-1182-4-5788d57586-vsklm   1/1     Running   1          23h   app=istiod,istio.io/rev=asm-1182-4,istio=istiod,pod-template-hash=5788d57586

    Nell'output, sotto la colonna LABELS, prendi nota del valore dell'etichetta di revisione istiod, che segue il prefisso istio.io/rev=. In questo esempio, il valore è asm-1182-4.

  2. Applica l'etichetta di revisione agli spazi dei nomi e rimuovi l'etichetta istio-injection (se esiste). Nel comando seguente, NAMESPACE è il nome dello spazio dei nomi in cui vuoi abilitare l'inserimento automatico e REVISION è l'etichetta di revisione che hai annotato nel passaggio precedente.

    kubectl label namespace NAMESPACE  istio-injection- istio.io/rev=REVISION --overwrite
    

    Puoi ignorare il messaggio "istio-injection not found" nell'output. Ciò significa che lo spazio dei nomi non aveva in precedenza l'etichetta istio-injection, come previsto nelle nuove installazioni di Anthos Service Mesh o nei nuovi deployment. Poiché il comportamento di auto-iniezione non è definito quando uno spazio dei nomi ha sia istio-injection sia l'etichetta di revisione, tutti i comandi kubectl label nella documentazione di Anthos Service Mesh assicurano esplicitamente che ne sia impostato solo uno.

  3. Riavvia i pod interessati, seguendo i passaggi nella sezione successiva.

Mesh di servizi gestito

  1. Utilizza il seguente comando per individuare i canali di rilascio disponibili:

    kubectl -n istio-system get controlplanerevision
    

    L'output è simile al seguente:

    NAME                AGE
    asm-managed         6d7h
    

    Nell'output, seleziona il valore nella colonna NAME corrispondente all'etichetta REVISION che corrisponde al canale di rilascio disponibile per la versione di Anthos Service Mesh. Applica questa etichetta agli spazi dei nomi e rimuovi l'etichetta istio-injection (se esistente). Nel comando seguente, sostituisci REVISION con l'etichetta di revisione annotata in precedenza e NAMESPACE con il nome dello spazio dei nomi in cui vuoi abilitare l'inserimento automatico:

    kubectl label namespace NAMESPACE  istio-injection- istio.io/rev=REVISION --overwrite
    

    Puoi ignorare il messaggio "istio-injection not found" nell'output. Ciò significa che lo spazio dei nomi non aveva in precedenza l'etichetta istio-injection, come previsto nelle nuove installazioni di Anthos Service Mesh o nei nuovi deployment. Poiché il comportamento di auto-iniezione non è definito quando uno spazio dei nomi ha sia istio-injection sia l'etichetta di revisione, tutti i comandi kubectl label nella documentazione di Anthos Service Mesh assicurano esplicitamente che ne sia impostato solo uno.

  2. Riavvia i pod interessati, seguendo i passaggi nella sezione successiva.

  3. Se hai eseguito anche il deployment del piano dati gestito da Google facoltativo, annota lo spazio dei nomi demo come segue:

    kubectl annotate --overwrite namespace YOUR_NAMESPACE \
    mesh.cloud.google.com/proxy='{"managed":"true"}'
    

Riavvia i pod per aggiornare i proxy sidecar

Con l'inserimento automatico di sidecar, puoi aggiornare i file collaterali per i pod esistenti con un riavvio dei pod:

La modalità di riavvio dei pod dipende dal fatto che siano stati creati nell'ambito di un deployment.

  1. Se hai utilizzato un deployment, riavvialo, che riavvia tutti i pod con i file collaterali:

    kubectl rollout restart deployment -n YOUR_NAMESPACE

    Se non hai utilizzato un deployment, elimina i pod, che verranno ricreati automaticamente con i file collaterali:

    kubectl delete pod -n YOUR_NAMESPACE --all
  2. Verifica che tutti i pod nello spazio dei nomi abbiano input collaterali:

    kubectl get pod -n YOUR_NAMESPACE

    Nell'output di esempio del comando precedente riportato di seguito, puoi notare che la colonna READY indica che esistono due container per ciascuno dei tuoi carichi di lavoro: il container principale e il container per il proxy sidecar.

    NAME                    READY   STATUS    RESTARTS   AGE
    YOUR_WORKLOAD           2/2     Running   0          20s
    ...
    

Passaggi successivi

Scopri di più su: