Cloud Service Broker Kf è un bundle di Service Broker che include Cloud Service Broker e Google Cloud Brokerpak open source. Viene resa disponibile come immagine Docker pubblica e pronta per il deployment come Servizio Kubernetes nei cluster Kf. Una volta eseguito il deployment del servizio Cloud Service Broker Kf in un cluster, gli sviluppatori possono eseguire il provisioning dei servizi di supporto Google Cloud tramite il servizio Cloud Service Broker Kf e associare i servizi di supporto alle app Kf.
Requisiti
- Kf Cloud Service Broker richiede un'istanza Cloud SQL per MySQL e un account di servizio per accedere all'istanza Cloud SQL per MySQL e ai servizi di supporto di Google Cloud. La connessione dal Service Broker Kf all'istanza Cloud SQL per MySQL passa attraverso il proxy di autenticazione Cloud SQL.
- Le richieste di accesso ai servizi Google Cloud (ad esempio Cloud SQL per MySQL o Memorystore) vengono autenticate tramite Workload Identity.
Sostituire i valori predefiniti di Brokerpak
I brokerpak sono essenzialmente un piano Terraform e le dipendenze correlate in un file Docker. Puoi esaminare i piani Terraform per vedere quali sono i valori predefiniti e poi puoi chiedere a Kf Cloud Service Broker di sostituirli quando crei nuovi servizi.
Ad esempio, la configurazione Terraform per Cloud SQL per MySQL include una variabile denominata authorized_network
. Se non viene sostituita, verrà utilizzata la VPC default
. Se vuoi sostituire il valore predefinito, puoi farlo durante la creazione del servizio. Ecco alcuni esempi:
Esegui l'override di
region
di computing.kf create-service csb-google-postgres small spring-music-postgres-db -c '{"region":"YOUR_COMPUTE_REGION"}'
Sostituisci
authorized_network
e calcolaregion
.kf create-service csb-google-postgres small spring-music-postgres-db -c '{"region":"YOUR_COMPUTE_REGION","authorized_network":"YOUR_CUSTOM_VPC_NAME"}'
Architettura
La seguente architettura di Cloud Service Broker Kf mostra come vengono create le istanze.
- Il Cloud Service Broker (CSB) Kf è installato nel proprio spazio dei nomi.
- Al momento dell'installazione, è necessario fornire un'istanza Cloud SQL per MySQL in modo che la logica di business usata da Kf Cloud Service Broker. Le richieste vengono inviate in modo sicuro dal pod Kf Cloud Service Broker all'istanza Cloud SQL per MySQL tramite il proxy di autenticazione Cloud SQL per MySQL.
- Per il provisioning dei servizi, una risorsa personalizzata di Kf Service viene creato. Il riconciliatore del servizio Kf fornisce i servizi di supporto Google Cloud utilizzando l'API Open Service Broker.
- Quando viene ricevuta una richiesta di provisioning/deprovisioning delle risorse di supporto, Kf Cloud Service Broker invia richieste di creazione/eliminazione delle risorse al corrispondente servizio Google Cloud e queste richieste vengono autenticate con Workload Identity. Inoltre, mantiene le logiche aziendali (ad es. mappatura dei servizi Kf ai servizi di supporto, associazioni di servizi) nell'istanza Cloud SQL per MySQL.
- Se la creazione del servizio di supporto è andata a buon fine, quest'ultimo è associato a un'App tramite VCAP_SERVICES.