Attivare l'accesso al sincronizzatore
Per attivare l'accesso al sincronizzatore:
- Crea un account di servizio Google Cloud e aggiungi il ruolo Amministratore dell'organizzazione Apigee. Questo account di servizio verrà utilizzato per autenticare una chiamata API che effettuerai in un passaggio successivo. Un modo semplice per creare l'account di servizio è tramite la console di Google Cloud.
Per le istruzioni, vedi
Creare e gestire gli account di servizio nella documentazione di Google Cloud.
Ad esempio, i seguenti comandi
gcloud
creano l'account di servizio e lo assegnano all'amministratore dell'organizzazione Apigee:- Crea l'account:
gcloud iam service-accounts create apigee-org-admin \ --display-name="apigee-org-admin"
dove apigee-org-admin è il nome dell'account di servizio che stai creando. Per questo tutorial è consigliato l'utilizzo di "
apigee-org-admin
". - Assegna il ruolo Amministratore dell'organizzazione Apigee all'account di servizio:
gcloud projects add-iam-policy-binding $PROJECT_ID \ --member="serviceAccount:apigee-org-admin@$PROJECT_ID.iam.gserviceaccount.com" \ --role="roles/apigee.admin"
Dove:
- $PROJECT_ID è il nome del progetto Google Cloud che hai creato nel passaggio 2: crea un progetto Google Cloud.
- apigee-org-admin è il nome dell'account di servizio che hai appena creato.
- roles/apigee.admin è il ruolo Apigee Org Admin.
- Crea l'account:
- Scarica la chiave dell'account di servizio sul tuo sistema. Utilizza il seguente comando per scaricare la chiave nella directory
service-accounts/
. Per ulteriori informazioni, consulta le istruzioni in Creare chiavi dell'account di servizio nella documentazione di Google Cloud.- Assicurati di essere nella directory
/hybrid-base-directory/hybrid-files/
. - Scarica la chiave:
gcloud iam service-accounts keys create ./service-accounts/$PROJECT_ID-apigee-org-admin.json \ --iam-account apigee-org-admin@$PROJECT_ID.iam.gserviceaccount.com
L'output dovrebbe essere simile al seguente:
created key [a0b1c2d3e4f5a0b1c2d3e4f5a0b1c2d3e4f5a0b1] of type [json] as [./service-accounts/hybrid- example-apigee-org-admin.json] for [apigee-org-admin@my-hybrid.iam.gserviceaccount.com] $
- Assicurati di essere nella directory
- Verifica il percorso della chiave dell'account di servizio Apigee Org Admin con il seguente comando:
ls service-accounts/*admin*
Il risultato dovrebbe essere simile al seguente:
service-accounts/hybrid-example-apigee-org-admin.json
- Crea una variabile di ambiente ORG_ADMIN_ACCOUNT con il nome del file della chiave.
Ad esempio:
export ORG_ADMIN_ACCOUNT="hybrid-example-apigee-org-admin.json"
- Esegui i seguenti comandi per ottenere un token:
export GOOGLE_APPLICATION_CREDENTIALS=./service-accounts/$ORG_ADMIN_ACCOUNT
export TOKEN=$(gcloud auth application-default print-access-token)
- Ottieni l'indirizzo email del tuo account di servizio
apigee-synchronizer
con il seguente comando:gcloud iam service-accounts list --filter "apigee-synchronizer"
Se corrisponde allo schema
apigee-synchronizer$ORG_NAME.iam.gserviceaccount.com
, puoi utilizzarlo nel passaggio successivo. - Chiama l'API setSyncAuthorization per attivare le autorizzazioni richieste per Synchronizer utilizzando il seguente comando:
curl -X POST -H "Authorization: Bearer $TOKEN" \ -H "Content-Type:application/json" \ "https://apigee.googleapis.com/v1/organizations/$ORG_NAME:setSyncAuthorization" \ -d '{"identities":["'"serviceAccount:apigee-synchronizer@$ORG_NAME.iam.gserviceaccount.com"'"]}'
Dove:
$ORG_NAME
: il nome dell'organizzazione ibrida.apigee-synchronizer$ORG_NAME.iam.gserviceaccount.com
: l'indirizzo email dell'account di servizio apigee-syncnronizer.
- Per verificare che l'account di servizio sia stato impostato, utilizza il seguente comando per chiamare l'API e ottenere un elenco di account di servizio:
curl -X POST -H "Authorization: Bearer $TOKEN" \ -H "Content-Type:application/json" \ "https://apigee.googleapis.com/v1/organizations/$ORG_NAME:getSyncAuthorization" \ -d ''
L'output è simile al seguente:
{ "identities":[ "serviceAccount:my-synchronizer-manager-service_account@my_project_id.iam.gserviceaccount.com" ], "etag":"BwWJgyS8I4w=" }
Applica la configurazione al cluster
Per installare Apigee hybrid nel cluster:
- Assicurati di essere nella directory
hybrid-base-directory/hybrid-files
. - Verifica che
kubectl
sia impostato sul contesto corretto utilizzando il seguente comando. Il contesto corrente deve essere impostato sul cluster in cui esegui il deployment di Apigee hybrid.kubectl config get-contexts
- Solo per le piattaforme AWS su GKE, EKS e GKE on-prem, verifica
che la variabile
KUBECONFIG
sia impostata utilizzando il seguente comando.echo $KUBECONFIG
- Esegui un'inizializzazione di simulazione. Esegui il comando
init
con il flag--dry-run
. Eseguire una prova secca ti consente di verificare la presenza di eventuali errori prima di apportare modifiche al cluster.Nella versione ibrida 1.4.4, la sintassi del flag
--dry-run
dipende dalla versione dikubectl
in esecuzione. Controlla la versione dikubectl
con il seguente comando:kubectl version
kubectl
versione 1.17 e precedenti:$APIGEECTL_HOME/apigeectl init -f overrides/overrides.yaml --dry-run=true
kubectl
versione 1.18 e successive:$APIGEECTL_HOME/apigeectl init -f overrides/overrides.yaml --dry-run=client
- Se non sono presenti errori, esegui il comando
init
come segue:$APIGEECTL_HOME/apigeectl init -f overrides/overrides.yaml
Il comando
init
installa i servizi di deployment di Apigee Apigee Deployment Controller e Apigee Admission Webhook. - Per controllare lo stato del deployment, puoi utilizzare i seguenti comandi:
$APIGEECTL_HOME/apigeectl check-ready -f overrides/overrides.yaml
kubectl get pods -n apigee-system
kubectl get pods -n istio-system
Quando i pod sono pronti, vai al passaggio successivo.
- Esegui una simulazione dell'installazione. Esegui il comando
apply
con il flag--dry-run
.kubectl
versione 1.17 e precedenti:$APIGEECTL_HOME/apigeectl apply -f overrides/overrides.yaml --dry-run=true
kubectl
versione 1.18 e successive:$APIGEECTL_HOME/apigeectl apply -f overrides/overrides.yaml --dry-run=client
-
Se non ci sono errori, puoi applicare i
componenti di runtime specifici di Apigee al cluster con il seguente comando:
$APIGEECTL_HOME/apigeectl apply -f overrides/overrides.yaml
- Per controllare lo stato del deployment, esegui il seguente comando:
$APIGEECTL_HOME/apigeectl check-ready -f overrides/overrides.yaml
Ripeti questo passaggio finché tutti i pod non sono pronti. L'avvio dei pod potrebbe richiedere diversi minuti.