Per archiviare dati e file su App Engine, puoi utilizzare i servizi Google Cloud o qualsiasi altro servizio di archiviazione supportato dalla tua lingua e accessibile dalla tua istanza App Engine. I database di terze parti possono essere ospitati su un altro cloud provider, on-premise o gestiti da un fornitore di terze parti.
Servizi di archiviazione di Google Cloud
Per le app App Engine in esecuzione nell'ambiente standard Java 8, consigliamo uno dei seguenti servizi di archiviazione di Google Cloud:
Nome | Struttura | Coerenza | Costo |
---|---|---|---|
Firestore in modalità Datastore | Senza schema (NoSQL) | Fortemente coerente tranne durante l'esecuzione di query globali. | La modalità Datastore offre una quota gratuita con limiti giornalieri. Gli account a pagamento offrono spazio di archiviazione illimitato, operazioni di lettura e scrittura. Ulteriori informazioni sono disponibili nella pagina Quote del datastore. |
Cloud SQL per MySQL o Cloud SQL per PostgreSQL |
Relazionale | Coerenza elevata | Google offre due piani di fatturazione per Google Cloud SQL: pacchetti e per uso. Ulteriori informazioni sono disponibili nel listino prezzi di Cloud SQL. |
Cloud Storage | File e metadati associati (archiviazione di file Cloud) | A elevata coerenza, tranne durante l'esecuzione di operazioni sugli elenchi che ricevono un elenco di bucket o oggetti. | Non sono previsti costi associati alle chiamate a Google Cloud Storage.
Tuttavia, ai dati archiviati in Google Cloud Storage vengono addebitate le normali tariffe di archiviazione dei dati di Google Cloud Storage. I prezzi di Cloud Storage sono disponibili nel listino prezzi di Cloud Storage. |
Queste opzioni non si escludono a vicenda. Ad esempio, la stessa applicazione può archiviare informazioni in un database Cloud SQL e anche i file in un bucket Cloud Storage.
Consulta un elenco completo dei prodotti di archiviazione Google Cloud nella pagina Prodotti Cloud Storage.
Altri cloud provider
Le app App Engine possono connettersi a database esterni ospitati su altri cloud pubblici, a condizione che i server di database e il firewall siano configurati correttamente per accettare le connessioni. L'app App Engine si connette su Internet utilizzando l'indirizzo IP pubblico di quel servizio esterno.
Database gestiti da un fornitore di terze parti
Esistono molti fornitori che offrono servizi di database gestiti come mLab per MongoDB, Redis Labs offre la memorizzazione di Redis in hosting. Questi fornitori gestiscono l'hosting, la configurazione e la manutenzione dei database. App Engine può connettersi a questi servizi esterni su Internet, come altri cloud pubblici, utilizzando l'indirizzo IP pubblico di quel servizio.
On-premise
Se disponi di database on-premise esistenti che vuoi rendere accessibili all'app App Engine, puoi configurare la rete interna e il firewall per assegnare al database un indirizzo IP pubblico o connetterti tramite una VPN.
Considerazioni sulla produzione
App Engine può essere configurato per scalare automaticamente l'applicazione in orizzontale in base a varie metriche. A differenza delle applicazioni web, i database spesso richiedono modifiche non banali per adattarsi alla scalabilità. Nelle applicazioni di produzione, App Engine può sovraccaricare rapidamente un database durante i picchi di traffico. Durante la configurazione e il deployment dei database, dovresti prendere in considerazione il carico e il carico medi previsti durante i picchi.