Dismissione di un'area geografica ibrida

Questa guida spiega la procedura per il ritiro di una regione in un ambiente multiregione.

Dismissione di un'area geografica ibrida

  1. Imposta i contesti Kubernetes per la regione che deve essere ritirata.

    Elenca i tuoi contesti attuali per vedere il nome del contesto per ogni cluster:

    kubectl config get-contexts

    Imposta il contesto del cluster e della regione che vuoi ritirare:

    kubectl config use-context CONTEXT_NAME

    dove CONTEXT_NAME è il nome del contesto per il cluster e la regione.

    Ad esempio:

    kubectl config get-contexts
      CURRENT  NAME                                                CLUSTER                                             AUTHINFO                                           NAMESPACE
               gke_example-org-1_us-central1_example-cluster-1     gke_example-org-1_us-central1_example-cluster-1     gke_example-org-1_us-central1_example-cluster-1    apigee
      *        gke_example-org-1_us-central1_example-cluster-2     gke_example-org-1_us-central1_example-cluster-2     gke_example-org-1_us-central1_example-cluster-2    apigee
               gke_example-org-1_us-west1_example-cluster-2        gke_example-org-1_us-west1_example-cluster-2        gke_example-org-1_us-west1_example-cluster-2       apigee
    
    kubectl config use-context gke_example-org-1_us-west1_example-cluster-2
  2. Verifica che tutti i pod nella regione siano in stato di esecuzione o completamento:
    kubectl get pods -n APIGEE_NAMESPACE
  3. Convalida il rilascio dei componenti utilizzando Helm:
    helm -n APIGEE_NAMESPACE list

    Ad esempio:

    helm -n apigee list
      NAME              NAMESPACE REVISION  UPDATED                                 STATUS    CHART                         APP VERSION
      datastore         apigee    2         2024-03-29 17:08:07.917848253 +0000 UTC	deployed  apigee-datastore-1.12.0       1.12.0
      ingress-manager   apigee    2         2024-03-29 17:21:02.917333616 +0000 UTC	deployed  apigee-ingress-manager-1.12.0 1.12.0
      redis             apigee    2         2024-03-29 17:19:51.143728084 +0000 UTC	deployed  apigee-redis-1.12.0           1.12.0
      telemetry         apigee    2         2024-03-29 17:16:09.883885403 +0000 UTC	deployed  apigee-telemetry-1.12.0       1.12.0
      exampleor         apigee    2         2024-03-29 17:21:50.899855344 +0000 UTC	deployed  apigee-org-1.12.0             1.12.0
  4. Convalida lo stato del cluster Cassandra.

    Elenca i pod Cassandra:

    kubectl get pods -n APIGEE_NAMESPACE -l app=apigee-cassandra

    Ad esempio:

    kubectl get pods -n apigee -l app=apigee-cassandra
      NAME                          READY    STATUS     RESTARTS    AGE
      apigee-cassandra-default-0    1/1      Running    0           2h
      apigee-cassandra-default-1    1/1      Running    0           2h
      apigee-cassandra-default-2    1/1      Running    0           2h
      apigee-cassandra-default-3    1/1      Running    0           16m
      apigee-cassandra-default-4    1/1      Running    0           14m
      apigee-cassandra-default-5    1/1      Running    0           13m
      apigee-cassandra-default-6    1/1      Running    0           9m
      apigee-cassandra-default-7    1/1      Running    0           9m
      apigee-cassandra-default-8    1/1      Running    0           8m
  5. Elimina l'istanza Apigee nel contesto che hai appena selezionato:

    Elimina i componenti uno alla volta.

    helm -n APIGEE_NAMESPACE delete datastore
    
    helm -n APIGEE_NAMESPACE delete telemetry
    
    helm -n APIGEE_NAMESPACE delete ingress-manager
    
    helm -n APIGEE_NAMESPACE delete redis
    
    helm -n APIGEE_NAMESPACE delete ORG_NAME
    

    Ripeti il seguente comando per ogni ambiente:

    helm -n APIGEE_NAMESPACE delete ENV_RELEASE_NAME
    

    Ripeti il seguente comando per ogni gruppo di ambienti:

    helm -n APIGEE_NAMESPACE delete ENV_GROUP_RELEASE_NAME
    
    helm -n APIGEE_NAMESPACE delete operator
    

    ENV_RELEASE_NAME e ENV_GROUP_RELEASE_NAME sono i nomi utilizzati per tenere traccia dell'installazione e degli upgrade dei grafici apigee-env e apigee-virtualhost. I nomi delle release di Helm devono essere univoci all'interno della tua installazione ibrida di Apigee. Se il nome dell'ambiente è univoco, può essere uguale a ENV_NAME. Tuttavia, se hai lo stesso nome per l'ambiente e il gruppo di ambienti, assicurati di inserire un nome di release Helm univoco per ciascuno. Ad esempio, se entrambi sono denominati dev, puoi utilizzare qualcosa come dev-env-release e dev-envgroup-release.

    Puoi visualizzare un elenco di nomi di release con il comando helm list:

    helm list -n APIGEE_NAMESPACE
    .

  6. Verifica che non ci siano pod rimanenti negli spazi dei nomi Apigee:
    kubectl get pods -n APIGEE_NAMESPACE
    
  7. Imposta il contesto su altre regioni esistenti e assicurati che il data center Cassandra venga rimosso dall'anello esistente. L'output non deve mostrare i dettagli del data center rimosso.
    kubectl exec apigee-cassandra-default-0 -n APIGEE_NAMESPACE  -- nodetool -u JMX_USER -pw JMX_PASSWORD status