Controlla l'idoneità del cluster ibrido
Prima di applicare la configurazione e installare il runtime ibrido, devi verificare che il cluster Kubernetes sia pronto per l'installazione di Apigee hybrid.
Per verificare l'idoneità del cluster, creerai un file YAML con una definizione di job Kubernetes e applicherai quel file con i comandi kubectl
per controllare il cluster.
Potrai quindi controllare lo stato del job di test Kubernetes con un comando kubectl get jobs
.
- Verifica che
kubectl
sia impostato sul contesto corretto utilizzando il seguente comando. Il contesto attuale deve essere impostato sul cluster in cui stai eseguendo il deployment di Apigee hybrid.kubectl config current-context
Il risultato dovrebbe includere il nome del cluster in cui stai eseguendo il deployment di Apigee hybrid. Ad esempio, su GKE, il nome del contesto è solitamente nel formato
gke_project-id_cluster-location_cluster-name
, ad esempio:gke_my-project_us-central1_my-cluster
Se il nome del cluster dei nomi nel contesto non corrisponde, il comando seguente riceverà le credenziali
gcloud
del cluster e imposterà il contestokubectl
:Cluster a livello di regione
gcloud container clusters get-credentials $CLUSTER_NAME \ --region $CLUSTER_LOCATION \ --project $PROJECT_ID
Cluster di zona
gcloud container clusters get-credentials $CLUSTER_NAME \ --zone $CLUSTER_LOCATION \ --project $PROJECT_ID
- Nella directory dei file ibridi, crea una directory
cluster-check
:mkdir $HYBRID_FILES/cluster-check
- Nella directory
$HYBRID_FILES/cluster-check
, crea un file denominatoapigee-k8s-cluster-ready-check.yaml
con il seguente contenuto:apiVersion: v1 kind: ServiceAccount metadata: name: apigee-k8s-cluster-ready-check --- apiVersion: batch/v1 kind: Job metadata: name: apigee-k8s-cluster-ready-check spec: template: spec: hostNetwork: true serviceAccountName: apigee-k8s-cluster-ready-check containers: - name: manager image: gcr.io/apigee-release/hybrid/apigee-operators:1.10.0 command: - /manager args: - --k8s-cluster-ready-check env: - name: POD_IP valueFrom: fieldRef: fieldPath: status.podIP securityContext: runAsGroup: 998 runAsNonRoot: true runAsUser: 999 restartPolicy: Never backoffLimit: 1
- Applica
apigee-k8s-cluster-ready-check.yaml
con il seguente comandokubectl
. Verrà eseguito il test:kubectl apply -f $HYBRID_FILES/cluster-check/apigee-k8s-cluster-ready-check.yaml
- Controlla lo stato del job Kubernetes con il seguente comando:
kubectl get jobs apigee-k8s-cluster-ready-check
Se il cluster è pronto, l'output dovrebbe essere simile a questo:
NAME COMPLETIONS DURATION AGE apigee-k8s-cluster-ready-check 1/1 8s 1h23m
Se il test non è riuscito e il cluster non è pronto, l'output dovrebbe essere simile a questo:
NAME COMPLETIONS DURATION AGE apigee-k8s-cluster-ready-check 0/1 44s 44s
Cerca il numero di completamenti:
- 1/1 Operazione riuscita, il tuo cluster è pronto per l'installazione ibrida di Apigee.
- 0/1 Il test non è riuscito. Il cluster non è pronto. Procedi con i seguenti passaggi per risolvere i problemi del cluster.
- Se il test non è riuscito, controlla i log con i comandi seguenti.
- Ottieni il nome del pod per il job di pre-controllo del cluster:
kubectl get pods | grep apigee-k8s-cluster-ready-check
- Recupera i log Kubernetes per il pod:
kubectl logs pod_name
Dove pod_name è il nome del pod apigee-k8s-cluster-ready-check.
- Ottieni il nome del pod per il job di pre-controllo del cluster:
- Esegui la pulizia prima di procedere con il passaggio successivo. Elimina il job Kubernetes con il seguente
comando:
kubectl delete -f $HYBRID_FILES/cluster-check/apigee-k8s-cluster-ready-check.yaml
Hai ora verificato che il tuo cluster ibrido Apigee sia pronto. Ora applichiamo la tua configurazione al runtime ibrido e completiamo l'installazione di Apigee hybrid.
Risoluzione dei problemi
- Controllo DNS Cassandra: se trovi log di errore simili a
DNS resolution was successful but IP doesn't match POD IP
,could not resolve hostname
oerror determining hostname
, significa che il DNS del tuo cluster non è configurato correttamente per una configurazione multiregionale. Puoi ignorare questo errore se non intendi configurare più regioni. - Controllo della connettività del piano di controllo: se trovi log di errore simili a
error creating TCP connection with host
, devi risolvere la connettività dal cluster a apigee.googleapis.com ed eseguire nuovamente il job.