Memorizzazione nella cache

Questa pagina descrive le opzioni a tua disposizione per controllare la memorizzazione nella cache degli oggetti Cloud Storage. Questa pagina si concentra sulla cache integrata di Cloud Storage e su Cloud CDN, ma Cloud Storage è compatibile anche con le CDN di terze parti.

Panoramica

Quando un oggetto Cloud Storage viene memorizzato nella cache, le copie dei dati dell'oggetto vengono memorizzate in una cache di Google o di internet in modo che l'oggetto possa essere servito più rapidamente nelle richieste future. Sebbene la memorizzazione nella cache possa migliorare le prestazioni, rischi anche di pubblicare contenuti obsoleti se aggiorni l'oggetto, ma una cache continua a pubblicare la versione precedente dell'oggetto.

Memorizzazione nella cache integrata per Cloud Storage

Cloud Storage può comportarsi come una rete di distribuzione dei contenuti (CDN) senza alcun intervento da parte tua, perché i dati di un oggetto vengono memorizzati nella cache della rete Cloud Storage se i relativi metadati Cache-Control sono impostati in modo da consentire la memorizzazione nella cache e se vengono soddisfatti i seguenti criteri:

Cloud Storage rispetta i valori standard per Cache-Control, ad esempio:

  • public: l'oggetto può essere memorizzato nella cache.

  • private: l'oggetto non verrà memorizzato nella cache da Cloud Storage, ma può essere memorizzato nella cache locale di un richiedente.

  • no-cache: l'oggetto può essere memorizzato nella cache, ma non può essere utilizzato per soddisfare richieste future a meno che non venga prima convalidato da Cloud Storage.

  • no-store: l'oggetto non può essere memorizzato nella cache.

  • max-age=TIME_IN_SECONDS: il periodo di tempo durante il quale un oggetto può essere memorizzato nella cache prima di essere considerato obsoleto. Puoi impostare max-age su qualsiasi durata. Gli oggetti obsoleti non vengono pubblicati dalle cache, tranne in circostanze speciali.

Per impostare i metadati Cache-Control per un oggetto, consulta Modifica dei metadati degli oggetti.

Comportamento di memorizzazione nella cache integrato con i criteri di negazione IAM

Quando esiste un criterio IAM Deny a livello di organizzazione che limita l'accesso in lettura per un oggetto dall'identificatore dell'entità allUsers, la memorizzazione nella cache integrata è disattivata per l'oggetto, anche se esiste un criterio IAM a livello di bucket che concede l'accesso in lettura per l'oggetto a allUsers. Tuttavia, se il criterio di negazione IAM limita solo i singoli utenti, la memorizzazione nella cache integrata rimane attiva per l'oggetto.

Considerazioni sulle prestazioni

Le prestazioni possono essere molto migliori per gli oggetti memorizzabili pubblicamente nella cache. Se utilizzi un oggetto per controllare molti client e vuoi disattivare la memorizzazione nella cache per fornire i dati più recenti:

  • Prova invece a impostare i metadati Cache-Control dell'oggetto su public con max-age di 15-60 secondi. La maggior parte delle applicazioni può tollerare che un oggetto non sia aggiornato per alcuni secondi, in cambio di miglioramenti delle prestazioni.

  • Utilizza Cache-Control: no-store per un oggetto per indicare che quell'oggetto non deve essere memorizzato nella cache per le successive richieste in qualsiasi cache.

Utilizzare Anywhere Cache con i bucket

Anywhere Cache è una funzionalità di Cloud Storage completamente gestita e sempre coerente che consente di creare cache nella stessa zona dei tuoi carichi di lavoro. Le cache possono quindi essere utilizzate per completare le richieste di lettura dei dati anziché il bucket multiregionale, aiutandoti a controllare i costi di archiviazione durante l'esecuzione di workload di grandi dimensioni e ad alta intensità di dati che altrimenti comporterebbero costi di trasferimento dei dati multiregionali e influirebbero sulle prestazioni. Per scoprire di più su Anywhere Cache, sui suoi vantaggi e su quando utilizzare questa funzionalità, consulta la panoramica di Anywhere Cache.

Cloud Storage con Cloud CDN

Per ottenere prestazioni ottimali durante la distribuzione dei contenuti agli utenti, ti consigliamo di utilizzare Cloud Storage con Cloud CDN.

Per utilizzare Cloud CDN, devi utilizzare un bilanciatore del carico delle applicazioni esterno con i tuoi bucket Cloud Storage come backend. Per un tutorial sulla configurazione di un bilanciatore del carico HTTP(S) con un bucket Cloud Storage, consulta Hosting di un sito web statico.

Le modalità cache di Cloud CDN consentono di applicare una configurazione di memorizzazione nella cache unificata a tutti gli oggetti. Cloud CDN utilizza i metadati Cache-Control impostati sugli oggetti per determinare come devono essere memorizzati nella cache, a meno che tu non esegua l'override dei metadati Cache-Control utilizzando una modalità cache o un limite TTL.

Quando scegli tra la memorizzazione nella cache integrata di Cloud Storage e Cloud CDN, tieni presente quanto segue:

Funzionalità Cloud Storage Cloud CDN
Dimensioni massime del file memorizzabile nella cache 10 MiB 100 GiB 1
Scadenza predefinita della cache 1 ora 1 ora (configurabile)
Supporto per domini personalizzati tramite HTTPS No
Annullamento convalida cache No

1La dimensione massima dei file memorizzabili nella cache per Cloud CDN è 100 GiB se il server di origine supporta le richieste di intervallo di byte. Se il server di origine non supporta le richieste di intervallo di byte, la dimensione massima del file memorizzabile nella cache per Cloud CDN è 10 MiB.

Considerazioni sui prezzi

In termini di prezzi, la scelta tra la memorizzazione nella cache integrata di Cloud Storage e Cloud CDN dipende dalla quantità di dati che pubblichi ogni mese, il che determina l'importo dei costi di rete che sostieni.

  • Se pubblichi meno di qualche GB di dati memorizzabili nella cache al mese, potrebbe essere più economico in generale fare affidamento alla memorizzazione nella cache integrata di Cloud Storage. La memorizzazione nella cache di Cloud Storage potrebbe comportare costi di rete più elevati rispetto a Cloud CDN, poiché gli oggetti memorizzati nella cache e non memorizzati nella cache vengono addebitati allo stesso costo di trasferimento dei dati in uscita (il che significa che paghi il prezzo intero per gli hit della cache). Tuttavia, paghi solo i costi di utilizzo delle operazioni e dell'archiviazione dei dati associati a Cloud Storage, anziché la combinazione di Cloud Storage, Cloud CDN e Cloud Load Balancing.

  • Se pubblichi regolarmente 100 GiB o più di dati memorizzabili nella cache al mese o devi utilizzare la registrazione per richiesta e le intestazioni personalizzate, potrebbe essere più conveniente affidarsi a Cloud CDN. Per il riempimento della cache, ti vengono addebitati i costi per il trasferimento di dati in uscita da Cloud Storage e per il riempimento della cache di Cloud CDN, mentre i prezzi di rete di Cloud CDN vengono applicati dopo che la cache è piena. Il risparmio sui costi di rete che ottieni dall'utilizzo di Cloud CDN potrebbe valere i costi operativi più elevati associati alla manutenzione del bilanciatore del carico delle applicazioni esterno e di Cloud CDN insieme a Cloud Storage.

Passaggi successivi