Crea un'app Ruby nell'ambiente flessibile di App Engine

ID regione

Il REGION_ID è un codice abbreviato che Google assegna in base alla regione selezionata quando crei l'app. Il codice non corrisponde a un paese o a una provincia, anche se alcuni ID regione possono sembrare simili ai codici di paesi e province di uso comune. Per le app create dopo febbraio 2020, REGION_ID.r è incluso negli URL App Engine. Per le app esistenti create prima di questa data, l'ID regione è facoltativo nell'URL.

Scopri di più sugli ID regione.

Questa guida rapida mostra come creare ed eseguire il deployment di un'app che visualizza un breve messaggio. Puoi utilizzare l'applicazione di esempio in questa guida rapida per qualsiasi versione supportata di Ruby specificando la versione del runtime e il sistema operativo nel file app.yaml.

Prima di iniziare

  1. 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.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. Verify that billing is enabled for your Google Cloud project.

  4. Enable the Cloud Build API.

    Enable the API

  5. Install the Google Cloud CLI.

  6. Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.

  7. Per inizializzare gcloud CLI, esegui questo comando:

    gcloud init
  8. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  9. Verify that billing is enabled for your Google Cloud project.

  10. Enable the Cloud Build API.

    Enable the API

  11. Install the Google Cloud CLI.

  12. Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.

  13. Per inizializzare gcloud CLI, esegui questo comando:

    gcloud init
  14. A causa delle modifiche al comportamento predefinito per il modo in cui Cloud Build utilizza i service account nei nuovi progetti e delle modifiche ai criteri dell'organizzazione sicuri per impostazione predefinita, potresti dover concedere ruoli aggiuntivi al account di servizio di deployment. Per ulteriori informazioni sulla concessione di ruoli specifici, consulta la guida alla risoluzione dei problemi.
  15. Prerequisiti aggiuntivi

    1. Inizializza la tua app App Engine con il tuo progetto e scegli la relativa area geografica:

      gcloud app create --project=[YOUR_PROJECT_ID]
      

      Quando richiesto, seleziona la regione in cui vuoi collocare l'applicazione App Engine.

    2. Installa quanto segue sulla tua macchina locale:

    Località App Engine

    App Engine è regionale, il che significa che l'infrastruttura che esegue le tue app si trova in una regione specifica e Google la gestisce in modo che sia disponibile in modo ridondante in tutte le zone all'interno di quella regione.

    Soddisfare i requisiti di latenza, disponibilità o durabilità è il fattore principale per la selezione della regione in cui vengono eseguite le tue app. In genere puoi selezionare la regione più vicina agli utenti della tua app, ma devi considerare le posizioni in cui è disponibile App Engine e le posizioni degli altri Google Cloud prodotti e servizi utilizzati dalla tua app. L'utilizzo di servizi in più località può influire sulla latenza della tua app e sui relativi prezzi.

    Non puoi modificare la regione di un'app dopo averla impostata.

    Se hai già creato un'applicazione App Engine, puoi visualizzarne la regione eseguendo una delle seguenti operazioni:

    Questa guida rapida mostra una semplice app Ruby scritta con il framework web Sinatra che puoi eseguire il deployment in App Engine. Sebbene questo esempio utilizzi Sinatra, puoi utilizzare altri framework come Ruby on Rails.

    scarica l'app Hello World

    Abbiamo creato un'app Hello World per App Engine in modo che tu possa farti rapidamente un'idea di come eseguire il deployment di un'app in Google Cloud.

    1. Clona il repository dell'app di esempio Hello World sulla tua macchina locale.

      git clone https://github.com/GoogleCloudPlatform/ruby-docs-samples
      

      In alternativa puoi scaricare l'esempio come file ZIP ed estrarlo.

    2. Passa alla directory che contiene il codice campione.

         cd ruby-docs-samples/appengine/flexible/hello_world
      

    Esegui Hello World sulla tua macchina locale

    Questo esempio utilizza Bundler per eseguire l'app Hello World sul computer locale:

    1. Se non hai già installato il linguaggio di programmazione per il tuo runtime, scarica e installa Ruby.

      Scaricare e installare Ruby

    2. Installa Bundler:

      gem install bundler
      
    3. Installa le dipendenze per questo progetto:

      bundle install
      
    4. Avvia un server web locale.

      bundle exec ruby app.rb -p 8080
      
    5. Nel browser web, inserisci:

      http://localhost:8080

    Sulla pagina viene visualizzato il messaggio Hello World dell'app di esempio. Nella finestra del terminale, premi Ctrl+C per uscire dal server web.

    Esegui il deployment di Hello World e avviala in App Engine

    Per eseguire il deployment dell'app nell'ambiente flessibile di App Engine:

    1. Esegui il deployment dell'app Hello World eseguendo il seguente comando dalla directory flexible/hello_world:

      gcloud app deploy

      Scopri di più sui flag facoltativi.

      Flag dei comandi gcloud comuni

      • Includi il flag --version per specificare un ID che identifichi in modo univoco quella versione della tua app. In caso contrario, ne verrà generato uno per te. Esempio: --version [YOUR_VERSION_ID]
      • Includi il flag --project per specificare un ID progetto Google Cloud alternativo a quello inizializzato come predefinito nello strumento gcloud. Esempio: --project [YOUR_PROJECT_ID]

      Esempio:

      gcloud app deploy --version pre-prod-5 --project my-sample-app

      Per scoprire di più sul deployment dell'app dalla riga di comando, consulta Test e deployment dell'app. Per un elenco di tutti i flag dei comandi, consulta la documentazione di riferimento di gcloud app deploy.

    2. Avvia il browser per visualizzare l'app all'indirizzo https://PROJECT_ID.REGION_ID.r.appspot.com

      gcloud app browse
      dove PROJECT_ID rappresenta l'ID progetto Google Cloud.

    Questa volta, la pagina che mostra il messaggio Hello World viene fornita da un server web in esecuzione su un'istanza App Engine.

    Complimenti! Hai eseguito il deployment della tua prima app App Engine nell'ambiente flessibile di App Engine.

    Se si sono verificati errori durante il deployment dell'applicazione, consulta i suggerimenti per la risoluzione dei problemi.

    Consulta le sezioni seguenti per informazioni sulla pulizia e link ai possibili passaggi successivi che puoi intraprendere.

    Esegui la pulizia

    Per evitare addebiti, puoi eliminare il tuo progetto Google Cloud per interrompere la fatturazione per tutte le risorse utilizzate al suo interno.

    1. In the Google Cloud console, go to the Manage resources page.

      Go to Manage resources

    2. In the project list, select the project that you want to delete, and then click Delete.
    3. In the dialog, type the project ID, and then click Shut down to delete the project.

    Passaggi successivi

    Imparare a usare l'intera piattaforma

    Ora che sai come sviluppare ed eseguire il deployment delle app App Engine, puoi esplorare il resto di Google Cloud. Hai già installato Google Cloud CLI, che ti fornisce gli strumenti per interagire con prodotti come Cloud SQL, Cloud Storage, Firestore e altri ancora.

    Scopri di più sull'ambiente flessibile di App Engine

    Ecco alcuni argomenti per continuare a imparare a utilizzare App Engine:

    Revisione del codice Hello World

    Hello World è l'app App Engine più semplice possibile, in quanto contiene un solo servizio, ha una sola versione e tutto il codice si trova nella directory principale dell'app. Questa sezione descrive in dettaglio ciascuno dei file dell'app.

    app.rb

    L'app Hello World è un'app Sinatra di base con un solo file:

    require "sinatra"
    
    get "/" do
      "Hello world!"
    end

    app.yaml

    Il file app.yaml descrive la seguente configurazione per la tua app:

    • Imposta env: flex, indicando che la tua app utilizza l'ambiente flessibile di App Engine.
    • Specifica il runtime utilizzato dall'app.

      runtime: ruby
      env: flex
      entrypoint: bundle exec ruby app.rb
      
      runtime_config:
        operating_system: ubuntu22
      
      # This sample incurs costs to run on the App Engine flexible environment.
      # The settings below are to reduce costs during testing and are not appropriate
      # for production use. For more information, see:
      # https://cloud.google.com/appengine/docs/flexible/ruby/configuring-your-app-with-app-yaml
      manual_scaling:
        instances: 1
      resources:
        cpu: 1
        memory_gb: 0.5
        disk_size_gb: 10
      

    Gemfile

    Gemfile viene utilizzato per specificare le dipendenze RubyGem dell'app, mentre Bundler viene utilizzato per dichiarare e installare le dipendenze. L'app Hello World richiede un gem Ruby: il framework web Sinatra:

    source "https://rubygems.org"
    
    gem "sinatra"
    gem "webrick", "~> 1.8"
    
    ruby "~>3.4"
    group :test do
      gem "rack-test"
      gem "rspec"
      gem "rspec_junit_formatter"
    end
    
    gem "puma", "~> 6.6"
    gem "rackup", "~> 2.2"