Le applicazioni spesso devono pubblicare file statici come JavaScript, immagini e CSS, oltre a gestire le richieste dinamiche. Le app nell'ambiente flessibile possono pubblicare file statici da un'opzione come Cloud Storage, pubblicarli direttamente o utilizzare una rete di distribuzione dei contenuti (CDN) di terze parti. Google Cloud
Pubblicazione di file da Cloud Storage
Cloud Storage può ospitare asset statici per app web dinamiche. I vantaggi dell'utilizzo di Cloud Storage anziché del servizio diretto dalla tua app includono:
- Cloud Storage funziona essenzialmente come una Content Delivery Network. Ciò non richiede alcuna configurazione speciale perché per impostazione predefinita qualsiasi oggetto leggibile pubblicamente viene memorizzato nella cache nella rete Cloud Storage globale.
- Il carico dell'app verrà ridotto scaricando la pubblicazione di asset statici su Cloud Storage. A seconda del numero di asset statici che hai e della frequenza di accesso, questo può ridurre notevolmente il costo di esecuzione dell'app.
- Gli addebiti per la larghezza di banda per l'accesso ai contenuti possono spesso essere inferiori con Cloud Storage.
Puoi caricare gli asset su Cloud Storage utilizzando Google Cloud CLI o l'API Cloud Storage.
La libreria client Google Cloud fornisce un client idiomatico per Cloud Storage, per archiviare e recuperare dati con Cloud Storage in un'app App Engine.
Esempio di pubblicazione da un bucket Cloud Storage
Questo esempio crea un bucket Cloud Storage e carica asset statici utilizzando gcloud CLI:
Crea un bucket. È comune, ma non obbligatorio, denominare il bucket in base all'ID progetto. Il nome del bucket deve essere univoco a livello globale.
gcloud storage buckets create gs://<var>your-bucket-name</var>
Imposta il criterio IAM per concedere l'accesso in lettura pubblico agli elementi nel bucket.
gcloud storage buckets add-iam-policy-binding gs://<var>your-bucket-name</var> --member=allUsers --role=roles/storage.objectViewer
Carica gli elementi nel bucket. Il comando
rsync
è in genere il modo più rapido e semplice per caricare e aggiornare gli asset. Puoi anche utilizzarecp
.gcloud storage rsync ./static gs://<var>your-bucket-name</var>/static --recursive
Ora puoi accedere alle tue risorse statiche tramite
https://storage.googleapis.com/<var>your-bucket-name</var>/static/...
.
Per ulteriori dettagli su come utilizzare Cloud Storage per pubblicare asset statici, incluso come pubblicarli da un nome di dominio personalizzato, consulta Come ospitare un sito web statico.
File per la pubblicazione da altri Google Cloud servizi
Hai anche la possibilità di utilizzare Cloud CDN o altri servizi di archiviazione Google Cloud .
Pubblicare file direttamente dalla tua app
La pubblicazione di file dalla tua app è in genere semplice, tuttavia ci sono un paio di svantaggi da considerare:
- Le richieste di file statici possono utilizzare risorse che altrimenti verrebbero utilizzate per richieste dinamiche.
- A seconda della configurazione, la pubblicazione di file dalla tua app può comportare una latenza della risposta, che può influire anche sul momento in cui vengono create nuove istanze per la gestione del carico.
Esempio di pubblicazione di file statici con la tua app
Vai
Il seguente esempio mostra come pubblicare file statici con la tua app. Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione supportata di Go specificando la versione del runtime e il sistema operativo nel file app.yaml
.
Puoi utilizzare lo standard
http.FileServer
o http.ServeFile
per pubblicare file direttamente dalla tua app.
Java
Il seguente esempio mostra come pubblicare file statici con la tua app. Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione supportata di Java specificando la versione del runtime e il sistema operativo nel file app.yaml
.
Il contenitore servlet del runtime Java utilizzerà il descrittore
di deployment,
il file web.xml
, della tua app per mappare gli URL alle servlet, incluse le risorse statiche. Se non
specifichi un web.xml
, viene utilizzato un valore predefinito che mappa tutto al servlet predefinito.
In questo esempio, ./src/main/webapp/index.html
si riferisce a un foglio di stile pubblicato
da /stylesheets/styles.css
.
Il file styles.css
si trova all'indirizzo ./src/main/webapp/stylesheets/styles.css
.
Puoi configurare esplicitamente la gestione dei file statici nel file web.xml
.
Ad esempio, se vuoi mappare le richieste per tutti i file con estensione .jpg
:
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
Se utilizzi un framework web, ad esempio Play, dovrai consultare la documentazione del framework sugli asset statici.
Node.js
Il seguente esempio mostra come pubblicare file statici con la tua app.
Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione supportata di Node.js specificando
la versione del runtime e il sistema operativo nel file app.yaml
.
La maggior parte dei framework web include il supporto per la pubblicazione di file statici. In questo esempio,
l'applicazione utilizza il
middleware express.static
per pubblicare i file dalla directory ./public
all'URL /static
.
La visualizzazione si riferisce a /static/main.css
.
Il foglio di stile si trova in ./public/css
, che viene servito da
/static/main.css
.
Altri framework Node.js, come Hapi, Koa e Sails in genere supportano la pubblicazione di file statici direttamente dall'applicazione. Per informazioni dettagliate su come configurare e utilizzare i contenuti statici, consulta la documentazione.
PHP
Il runtime PHP esegue nginx
per pubblicare la tua app, che è configurata per pubblicare file statici nella
directory del progetto. Devi dichiarare la radice del documento specificando
document_root
nel file app.yaml
. Puoi utilizzare l'applicazione di esempio
in questa guida per qualsiasi versione supportata di PHP specificando
la versione del runtime e il sistema operativo nel file app.yaml
.
Python
Il seguente esempio mostra come pubblicare file statici con la tua app. Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione di Python supportata specificando la versione del runtime e il sistema operativo nel file app.yaml
.
La maggior parte dei framework web include il supporto per la pubblicazione di file statici. In questo esempio,
l'app utilizza la funzionalità integrata di Flask
per pubblicare i file nella directory ./static
dall'URL /static
.
L'app include una visualizzazione che esegue il rendering del modello. Flask gestisce automaticamente
tutto ciò che si trova nella directory ./static
senza configurazione aggiuntiva.
Il modello visualizzato dalla vista include un foglio di stile che si trova in
/static/main.css
.
Il foglio di stile si trova in ./static/main.css
.
Altri framework Python, come Django, Pyramid e Bottle, in genere supportano la pubblicazione di file statici direttamente dall'app. Consulta la documentazione per informazioni dettagliate su come configurare e utilizzare i contenuti statici.
Ruby
La maggior parte dei framework web include il supporto per la pubblicazione di file statici.
Il seguente esempio mostra come pubblicare file statici con la tua app.
Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione supportata di Ruby specificando la versione del runtime e il sistema operativo nel file app.yaml
.
Sinatra
Il framework web Sinatra
serve i file dalla directory ./public
per impostazione predefinita. Questa
app include una visualizzazione che fa riferimento a /application.css
.
Il foglio di stile si trova in ./public/application.css
, che viene servito
da /application.css
.
Ruby on Rails
Il framework web Ruby on Rails
serve i file dalla directory ./public
per impostazione predefinita. I file JavaScript e CSS statici possono essere generati anche dalla pipeline
delle risorse di Rails.
Queste app di esempio contengono una visualizzazione del layout che include tutti i fogli di stile dell'applicazione.
Il foglio di stile è un file .css
che si trova in ./public/application.css
.
Per impostazione predefinita, le app Rails non generano né pubblicano asset statici quando vengono eseguite in produzione.
Il runtime Ruby esegue rake assets:precompile
durante il deployment
per generare asset statici e imposta la variabile di ambiente RAILS_SERVE_STATIC_FILES
per attivare la pubblicazione di file statici in produzione.
.NET
Il seguente esempio mostra come pubblicare file statici con la tua app. Puoi utilizzare l'applicazione di esempio in questa guida per qualsiasi versione supportata di .NET specificando la versione del runtime e il sistema operativo nel file app.yaml
.
Per attivare la pubblicazione di file statici, aggiungi:
Pubblicazione da una rete CDN (Content Delivery Network) di terze parti
Puoi utilizzare qualsiasi CDN esterna di terze parti per pubblicare i tuoi file statici e memorizzare nella cache le richieste dinamiche, ma la tua app potrebbe riscontrare un aumento della latenza e dei costi.
Per migliorare le prestazioni, devi utilizzare una CDN di terze parti che supporti CDN Interconnect.