Questo tutorial mostra come iniziare a utilizzare Compute Engine. Segui questo tutorial eseguendo il deployment di un'app web Ruby di Hello World in Compute Engine. Per iniziare a utilizzare App Engine, consulta l'ambiente standard di App Engine.
Obiettivi
- Utilizza Cloud Shell per scaricare e sottoporre a deployment un'app di esempio Hello World.
- Eseguire il deployment di un'app Hello World di esempio in una singola istanza di Compute Engine.
Costi
In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:
Per generare una stima dei costi basata sull'utilizzo previsto,
utilizza il Calcolatore prezzi.
Prima di iniziare
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Compute Engine API.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Compute Engine API.
-
In Google Cloud Console, apri l'app in Cloud Shell.
Cloud Shell fornisce l'accesso tramite riga di comando alle tue risorse cloud direttamente dal browser.
-
Se accetti di clonare il repository, fai clic su Conferma per scaricare il codice di esempio e passare alla directory dell'app.
-
In Cloud Shell, configura l'interfaccia a riga di comando gcloud in modo da utilizzare il nuovo progetto Google Cloud:
# Configure gcloud for your project gcloud config set project YOUR_PROJECT_ID
Esecuzione dell'app in Cloud Shell
In Cloud Shell, installa le dipendenze dell'applicazione utilizzando
bundle
:bundle install
Esegui l'app Sinatra:
bundle exec ruby app.rb -p 8080
In Cloud Shell, fai clic su Anteprima web , e seleziona Anteprima sulla porta 8080. Compare una nuova finestra in cui viene eseguita l'app.
Per arrestare il server web locale premi CTRL+C.
Distribuzione su una singola istanza
Questa sezione ti guiderà attraverso l'esecuzione di una singola istanza della tua app in Compute Engine.
Da Cloud Shell, puoi eseguire il deployment in una singola macchina virtuale (VM) di istanze Compute Engine che esegue la tua app.
Usa uno script di avvio per inizializzare un'istanza
Hai bisogno di un metodo per impostare l'istanza in modo da scaricare ed eseguire il codice. Un'istanza può avere uno script di avvio eseguito ogni volta che l'istanza viene avviata o riavviata.
Lo script di avvio esegue queste attività:
Installa l'agente Cloud Logging. L'agente raccoglie automaticamente i log da syslog.
Installa Ruby 2.6.5, Bundler e le sue dipendenze di sistema.
Clona il codice sorgente dell'app da Cloud Source Repositories e installa le dipendenze.
Installa e configura Nginx.
Installa Supervisor per eseguire l'app come daemon.
Configura Supervisor per eseguire l'app. Supervisor assicura che l'app venga riavviata se esce inaspettatamente o viene terminata da un amministratore o da un altro processo. Inoltre, invia l'elemento
stdout
e l'elementostderr
dell'app al sistema syslog affinché venga raccolto dall'agente Logging.
Creare e configurare un'istanza di Compute Engine
Crea un'istanza Compute Engine:
Linux/macOS
Windows
gcloud compute instances create my-app-instance ^ --image-family=debian-9 ^ --image-project=debian-cloud ^ --machine-type=g1-small ^ --scopes userinfo-email,cloud-platform ^ --metadata-from-file startup-script=gce/startup-script.sh ^ --zone us-central1-a ^ --tags http-server
Sostituisci la zona con una zona di sviluppo, ad esempio
us-central1-a
. Per saperne di più sulle aree geografiche e sulle zone, consulta Area geografica e aree geografiche.Viene creata una nuova istanza, consente di accedere ai servizi Google Cloud ed esegue lo script di avvio. Il nome dell'istanza è
my-app-instance
.Verifica lo stato di avanzamento della creazione dell'istanza:
gcloud compute instances get-serial-port-output my-app-instance --zone YOUR_ZONE
Sostituisci
YOUR_ZONE
con la zona in cui hai eseguito il deployment dell'istanza.Al termine dello script di avvio, viene visualizzato il seguente messaggio:
startup-script: INFO Finished running startup scripts.
Crea una regola firewall per consentire il traffico nell'istanza:
gcloud compute firewall-rules create default-allow-http-80 \ --allow tcp:80 \ --source-ranges 0.0.0.0/0 \ --target-tags http-server \ --description "Allow port 80 access to http-server"
Ottieni l'indirizzo IP esterno dell'istanza:
gcloud compute instances list
Per visualizzare l'app in esecuzione, inserisci questo URL nel browser:
http://YOUR_INSTANCE_IP
Sostituisci
YOUR_INSTANCE_IP
con l'indirizzo IP esterno della tua istanza.
Gestire e monitorare un'istanza
Puoi utilizzare Google Cloud Console per monitorare e gestire la tua istanza.
- In the Google Cloud console, go to the VM instances page.
- In the list of virtual machine instances, click SSH in the row of the instance that you want to connect to.
- Per visualizzare tutti i log generati dalle risorse Compute Engine, vai alla pagina Esplora log.
Vai a Esplora log
Cloud Logging è configurato automaticamente per raccogliere log da vari servizi comuni, tra cui
syslog
.
Esegui la pulizia
Per evitare che al tuo Account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questo tutorial, elimina il progetto che contiene le risorse oppure mantieni il progetto ed elimina le singole risorse.
Elimina il progetto
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
Elimina le singole risorse
gcloud compute instances delete my-app-instance --zone=YOUR_ZONE --delete-disks=all gcloud compute firewall-rules delete default-allow-http-80