Questa pagina contiene informazioni ed esempi per la connessione a un'istanza Cloud SQL da un servizio in esecuzione in Cloud Run Functions.
Per istruzioni passo passo sull'esecuzione di un'applicazione web di esempio di Cloud Run Functions connessa a Cloud SQL, consulta laguida rapida per la connessione da Cloud Run Functions.
Cloud SQL è un servizio di database completamente gestito che semplifica la configurazione, la manutenzione, la gestione e l'amministrazione dei database relazionali nel cloud.
Cloud Run Functions è una soluzione di calcolo leggera che consente agli sviluppatori di creare funzioni autonome a uso specifico, che rispondano a eventi Cloud senza la necessità di gestire un ambiente server o di runtime.
Configura un'istanza Cloud SQL
- Se non l'hai già fatto, abilita l'API Cloud SQL Admin nel Google Cloud progetto da cui ti stai connettendo:
Ruoli richiesti per abilitare le API
Per abilitare le API, devi disporre del ruolo IAM Amministratore utilizzo servizi (
roles/serviceusage.serviceUsageAdmin), che contiene l'autorizzazioneserviceusage.services.enable. Scopri come concedere i ruoli. - Crea un'istanza Cloud SQL
per SQL Server. Ti consigliamo di scegliere una località dell'istanza Cloud SQL
nella stessa regione del servizio Cloud Run per una latenza migliore, per evitare alcuni costi di rete e per ridurre
i rischi di errori tra regioni.
Per impostazione predefinita, Cloud SQL assegna un indirizzo IP pubblico a una nuova istanza. Hai anche la possibilità di assegnare un indirizzo IP privato. Per ulteriori informazioni sulle opzioni di connettività per entrambi, consulta la Panoramica della connessione pagina.
- Quando crei l'istanza, puoi scegliere la
gerarchia dei certificati server (CA) per l'istanza e poi configurarla come
come
serverCaModeper l'istanza. Devi selezionare l' opzione CA per istanza (GOOGLE_MANAGED_INTERNAL_CA) come modalità CA server per le istanze a cui vuoi connetterti dalle applicazioni web.
Configura Cloud Run Functions
I passaggi per configurare Cloud Run Functions dipendono dal tipo di indirizzo IP assegnato all'istanza Cloud SQL.IP pubblico (predefinito)
Cloud Run Functions supporta la connessione a Cloud SQL per SQL Server tramite IP pubblico utilizzando i connettori Go, Java e Python.
Per configurare Cloud Run Functions in modo da abilitare le connessioni a un'istanza Cloud SQL:- Verifica che l'istanza creata sopra abbia un indirizzo IP pubblico. Puoi verificarlo nella pagina Panoramica dell'istanza nella Google Cloud console. Se devi aggiungere un indirizzo IP pubblico, consulta Configura l'IP pubblico.
- Recupera il valore INSTANCE_CONNECTION_NAME dell'istanza. Questo valore è
disponibile:
- Nella pagina Panoramica dell'istanza, nella Google Cloud console, oppure
- Eseguendo il comando seguente:
gcloud sql instances describe [INSTANCE_NAME]
-
Configura il service account per la tua funzione. Se il account di servizio di autorizzazione appartiene a un progetto diverso dall'istanza Cloud SQL, devi abilitare l'API Cloud SQL Admin e aggiungere il
Cloud SQL Clientruolo IAM a entrambi i progetti. - Verifica che il account di servizio disponga di questo ruolo in modo che l'account possa connettersi a Cloud SQL.
- Se utilizzi
Cloud Run Functions e non Cloud Run Functions (1ª generazione), sono
necessari i seguenti passaggi (vedi anche
Configura Cloud Run):
- Esegui il deployment iniziale della funzione.
Quando inizi a creare una funzione Cloud Run nella Google Cloud console, il servizio Cloud Run sottostante non è ancora stato creato. Non puoi configurare una connessione Cloud SQL finché non viene creato il servizio (eseguendo il deployment della funzione Cloud Run). - Nella Google Cloud console, in alto a destra della pagina Dettagli funzione , fai clic sul link sotto Con tecnologia Cloud Run per accedere al servizio Cloud Run sottostante.
- Nella pagina Dettagli servizio di Cloud Run, seleziona la scheda Modifica ed esegui il deployment di una nuova revisione.
- Segui i
passaggi standard
(come nel caso di qualsiasi modifica alla configurazione
) per impostare una nuova configurazione per una connessione Cloud SQL.
Viene creata una nuova revisione di Cloud Run e le revisioni successive ricevono automaticamente questa connessione Cloud SQL, a meno che tu non la modifichi esplicitamente.
- Esegui il deployment iniziale della funzione.
IP privato
Se il account di servizio di autorizzazione appartiene a un progetto diverso da quello contenente l'istanza Cloud SQL, procedi come segue:
- In entrambi i progetti, abilita l'API Cloud SQL Admin.
- Per il account di servizio nel progetto che contiene l'istanza Cloud SQL, aggiungi le autorizzazioni IAM.
- Assicurati che l'istanza Cloud SQL creata in precedenza abbia un indirizzo IP privato. Se devi aggiungerne uno, consulta Configura l'IP privato per le istruzioni.
- Crea un connettore di accesso VPC serverless nella stessa rete VPC dell'istanza Cloud SQL. Tieni presente le seguenti condizioni:
- A meno che tu non utilizzi VPC condiviso, il connettore deve trovarsi nello stesso progetto e nella stessa regione della risorsa che lo utilizza, ma può inviare traffico a risorse in regioni diverse.
- L'accesso VPC serverless supporta la comunicazione con le reti VPC connesse tramite Cloud VPN e peering di rete VPC.
- L'accesso VPC serverless non supporta le reti legacy.
- Configura Cloud Run Functions per utilizzare il connettore.
- Connettiti utilizzando l'indirizzo IP privato e la porta
1433dell'istanza.
Connettiti a Cloud SQL
Dopo aver configurato Cloud Run Functions, puoi connetterti all'istanza Cloud SQL.
IP pubblico (predefinito)
Per i percorsi IP pubblici, Cloud Run Functions fornisce la crittografia e si connette utilizzando i connettori Cloud SQL.
Connettiti con i connettori Cloud SQL
I connettori Cloud SQL sono librerie specifiche del linguaggio che forniscono la crittografia e l'autorizzazione basata su IAM quando si connettono a un'istanza Cloud SQL.
Python
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Java
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Nota:
- CLOUD_SQL_CONNECTION_NAME deve essere rappresentato come <MY-PROJECT>:<INSTANCE-REGION>:<INSTANCE-NAME>
- Consulta i requisiti della versione della factory di socket JDBC per il file pom.xml file qui .
Vai
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Node.js
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
IP privato
Per i percorsi IP privati, l'applicazione si connette direttamente all'istanza tramite una rete VPC. Questo metodo utilizza TCP per connettersi direttamente all'istanza Cloud SQL senza utilizzare il proxy di autenticazione Cloud SQL.
Connettiti con TCP
Connettiti utilizzando l'indirizzo IP privato dell'istanza Cloud SQL come host e la porta 1433.
Python
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Java
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Nota:
- CLOUD_SQL_CONNECTION_NAME deve essere rappresentato come <MY-PROJECT>:<INSTANCE-REGION>:<INSTANCE-NAME>
- L'utilizzo dell'argomento ipTypes=PRIVATE forzerà SocketFactory a connettersi con l'IP privato associato a un'istanza
- Consulta i requisiti della versione della factory di socket JDBC per il file pom.xml.
Node.js
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Vai
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
PHP
Per visualizzare questo snippet nel contesto di un'applicazione web, consulta il file README su GitHub.
Best practice e altre informazioni
Puoi utilizzare il proxy di autenticazione Cloud SQL quando testi l'applicazione in locale. Per istruzioni dettagliate, consulta la guida rapida per l'utilizzo del proxy di autenticazione Cloud SQL.
Pool di connessioni
Le connessioni ai database sottostanti potrebbero essere interrotte dal server di database stesso o dall'infrastruttura sottostante di Cloud Run Functions. Ti consigliamo di utilizzare una libreria client che supporti i pool di connessioni che si riconnettono automaticamente alle connessioni client interrotte. Inoltre, ti consigliamo di utilizzare un pool di connessioni con ambito globale per aumentare la probabilità che la funzione riutilizzi la stessa connessione per le invocazioni successive e chiuda la connessione in modo naturale quando l'istanza viene eliminata (ridimensionamento automatico). Per esempi più dettagliati su come utilizzare i pool di connessioni, consulta Gestire le connessioni ai database.Limiti di connessione
Cloud SQL impone un limite massimo alle connessioni simultanee e questi limiti possono variare a seconda del motore del database scelto (vedi Quote e limiti di Cloud SQL). È consigliabile utilizzare una connessione con Cloud Run Functions, ma è importante impostare il numero massimo di connessioni su 1.Ove possibile, devi assicurarti di inizializzare un pool di connessioni solo per funzioni che devono accedere al database. Alcuni pool di connessioni creano connessioni in modo preventivo, il che può consumare risorse in eccesso e rientrare nei limiti di connessione. Per questo motivo, ti consigliamo di utilizzare l'inizializzazione lenta per ritardare la creazione di un pool di connessioni fino a quando non è necessario e di includere il pool di connessioni solo nelle funzioni in cui viene utilizzato.
Per esempi più dettagliati su come limitare il numero di connessioni, consulta Gestire le connessioni ai database.
Limiti di quota API
Cloud Run Functions fornisce un meccanismo che si connette utilizzando il proxy di autenticazione Cloud SQL, che utilizza l'API Cloud SQL Admin. I limiti di quota API si applicano al proxy di autenticazione Cloud SQL. La quota dell'API Cloud SQL Admin utilizzata è circa il doppio del numero di istanze Cloud SQL configurate moltiplicato per il numero totale di funzioni di cui è stato eseguito il deployment. Puoi impostare il numero massimo di invocazioni simultanee per modificare la quota API prevista consumata. Cloud Run Functions impone anche limiti di frequenza al numero di chiamate API consentite ogni 100 secondi.
Passaggi successivi
- Scopri di più su Cloud Run Functions.
- Scopri di più sul deployment di funzioni in Cloud Run Functions.
- Scopri di più sulla specifica dei trigger per Cloud Run Functions.
- Scopri di più sulla configurazione di Cloud Run Functions.