Passaggio 1: creazione di un cluster

Prima di iniziare:

Questi passaggi presuppongono che tu abbia creato variabili di ambiente nei passaggi precedenti. Controllali con i seguenti comandi:

echo $PROJECT_ID
echo $ANALYTICS_REGION
echo $ORG_NAME
echo $ENV_NAME

Questo passaggio spiega come configurare l'ambiente shell e creare un cluster GKE nel progetto Google Cloud.

Configura la shell del terminale

Lo strumento gcloud fornisce l'interfaccia a riga di comando principale per Google Cloud, mentre kubectl fornisce l'interfaccia a riga di comando principale per l'esecuzione di comandi sui cluster Kubernetes.

  1. Assicurati di aver installato gcloud e kubectl nella shell locale. Lo strumento gcloud fornisce l'interfaccia a riga di comando principale per Google Cloud, mentre kubectl fornisce l'interfaccia a riga di comando principale per l'esecuzione di comandi sui cluster Kubernetes.

    gcloud -h
    kubectl -h
  2. Se non hai installato queste utilità, installale come segue:
    1. Installa Cloud SDK, che include lo strumento a riga di comando gcloud.
    2. Dopo aver installato Cloud SDK, installa lo strumento a riga di comando kubectl eseguendo questo comando:
    3. gcloud components install kubectl
  3. Utilizza lo strumento gcloud per configurare due impostazioni predefinite: il progetto predefinito e la regione di computing. La configurazione di queste impostazioni semplifica l'esecuzione dei comandi gcloud, perché gcloud richiede di specificare il progetto e la regione di computing in cui vuoi lavorare.

    Per visualizzare l'elenco delle impostazioni correnti, esegui questo comando:

    gcloud config list

    Se un progetto e/o una regione di computing non sono elencati, devi aggiungerli con i comandi mostrati di seguito. Se, dall'output dell'elenco, determini che devi cambiare le impostazioni attuali in modo che riflettano il tuo progetto e la regione di computing, puoi anche utilizzare questi comandi:

    gcloud config set project $PROJECT_ID
    gcloud config set compute/region $ANALYTICS_REGION
    

    Dove:

    • PROJECT_ID è il nome del tuo progetto Google Cloud.
    • ANALYTICS_REGION è il nome di una regione di computing di Google Cloud

crea un cluster GKE

In questo passaggio creerai un cluster Kubernetes nel tuo progetto Google Cloud (il progetto che hai impostato con il comando gcloud config rappresentato da PROJECT_ID).

Crea il cluster

  1. (Facoltativo) Crea la variabile di ambiente CLUSTER_NAME con il comando seguente:
    export CLUSTER_NAME=cluster-name

    Dove cluster-name è il nome che scegli per il cluster.

  2. Esegui questo comando per creare il cluster. Il tipo di macchina, il numero di nodi e altre impostazioni specificate nel comando creano un cluster con configurazione minima, adatto per un'installazione ibrida di prova di Apigee.
    gcloud container clusters create $CLUSTER_NAME \
    --machine-type "e2-standard-4" --num-nodes "4" --enable-autoscaling --min-nodes "3" --max-nodes "6"

    La creazione del cluster può richiedere alcuni minuti. Se l'operazione va a buon fine, viene visualizzato un output simile al seguente, con stato RUNNING:

    NAME           LOCATION       MASTER_VERSION  MASTER_IP     MACHINE_TYPE   NODE_VERSION   NUM_NODES  STATUS
    apigee-hybrid  us-central1    1.15.12-gke.2   35.222.54.89  e2-standard-4  1.15.12-gke.2             RUNNING

Imposta il contesto corrente

Un contesto è un gruppo di parametri di accesso. Ogni contesto contiene un cluster Kubernetes, un utente e uno spazio dei nomi. Il contesto attuale è il cluster attualmente predefinito per kubectl: tutti i comandi kubectl vengono eseguiti su quel cluster.

Assicurati che il contesto gcloud attuale sia impostato sul cluster che hai appena creato.

  1. Per prima cosa, elenca i contesti per determinare qual è quello attuale. Nell'esempio seguente, il contesto attuale è gke_hybrid-project_us-central1_apigee-hybrid. Il nome include il nome di un progetto Google Cloud (hybrid-project), una regione (us-central1) e il nome di un cluster (apigee-hybrid).
    kubectl config get-contexts

    I risultati dovrebbero avere un aspetto simile al seguente esempio:

    CURRENT   NAME                                             CLUSTER                                          AUTHINFO                                           NAMESPACE
    *         gke_hybrid-project_us-central1_apigee-hybrid     gke_hybrid-project_us-central1_apigee-hybrid     gke_hybrid-project_us-central1_apigee-hybrid
              gke_apigee-project_us-west1_apigee-cluster       gke_apigee-project_us-west1_apigee-cluster       gke_apigee-project_us-west1_apigee-cluster
    
  2. Se necessario, imposta il contesto attuale per il cluster appena creato (quello in cui intendi installare Apigee hybrid). Utilizzando l'output get-contexts precedente, puoi passare al contesto corretto, come segue:
    kubectl config use-context context

    Dove context è il nome completo del contesto del cluster come output del comando get-contexts precedente. Ad esempio: gke_apigee-project_us-west1_apigee-cluster.

  3. Controlla il contesto attuale per assicurarti che sia impostato sul cluster previsto utilizzando questo comando:
    kubectl config current-context

    Ad esempio:

    gke_apigee-project_us-west1_apigee-cluster

Concedi credenziali per il cluster

Le credenziali del cluster ti consentono di accedere ai container in esecuzione nel cluster. Recupera le tue credenziali e concediti il ruolo cluster-admin:

  1. Recupera le credenziali inserendo il seguente comando:
    gcloud container clusters get-credentials $CLUSTER_NAME

    Dove CLUSTER_NAME è il nome, corrisponde al nome del cluster che hai creato (quello in cui intendi installare Apigee hybrid).

    Dovresti vedere un risultato simile al seguente:

    Fetching cluster endpoint and auth data.
    kubeconfig entry generated for example-cluster.
  2. Imposta l'associazione dei ruoli nel cluster. Esegui questo comando esattamente come mostrato:
    kubectl create clusterrolebinding cluster-admin-binding \
    --clusterrole cluster-admin --user $(gcloud config get-value account)

    Dovresti vedere un risultato simile al seguente:

    clusterrolebinding.rbac.authorization.k8s.io/cluster-admin-binding created

Riepilogo

Ora hai un cluster Kubernetes in esecuzione nel tuo progetto Google Cloud. L'ambiente shell è configurato ed è tutto pronto per installare i servizi cert-manager e istio richiesti da Apigee hybrid sulla tua macchina locale.

1 (AVANTI) Passaggio 2: installa cert-manager e ASM 3 4 5