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 descrive come eseguire il deployment delle app nell'ambiente standard in Cloud Run utilizzando Google Cloud CLI. Le istruzioni sono applicabili ai runtime di seconda generazione che non utilizzano i servizi in bundle legacy di App Engine.
Cloud Run utilizza gran parte della stessa infrastruttura dell'ambiente standard di App Engine, il che comporta molte somiglianze tra le piattaforme. Per scoprire di più sulle somiglianze e differenze tra App Engine e Cloud Run, inclusi i vantaggi della migrazione a Cloud Run, consulta il riepilogo del confronto.
Per eseguire il deployment in Cloud Run utilizzando il comando gcloud beta app migrate,
scegli una delle seguenti strategie:
Utilizza il file
app.yamlper eseguire il deployment di un servizio in Cloud Run utilizzando la configurazione App Engine esistente.Esegui il deployment di un'applicazione App Engine esistente direttamente in Cloud Run.
Prima di iniziare
Assicurati di avere accesso al codice sorgente di App Engine e che l'applicazione App Engine venga eseguita senza errori.
Abilita l'API Cloud Run Admin e l'API Artifact Registry:
Configura il progetto e la regione utilizzando il seguente comando:
gcloud auth login gcloud config set project PROJECT_ID gcloud config set run/region REGION gcloud components updateSostituisci quanto segue:
- PROJECT_ID con l'ID progetto Google Cloud .
- REGION con la tua regione.
Esamina le funzionalità incompatibili nella tua applicazione e rimuovile prima di eseguire la migrazione a Cloud Run. Se nell'applicazione esistente sono presenti funzionalità incompatibili, il processo di migrazione si interrompe ed elenca le incompatibilità.
Esamina le seguenti differenze di Cloud Run:
Cloud Run utilizza il termine
Revision, anzichéVersion, per rappresentare ogni volta che esegui il deployment delle modifiche a un servizio specifico. Eseguendo il deployment della tua app in un servizio in Cloud Run per la prima volta viene creata la prima revisione. Ogni deployment successivo di un servizio crea un'altra revisione. Scopri di più sul deployment in Cloud Run.Puoi eseguire il deployment del codice sorgente su Cloud Run utilizzando gcloud CLI o la console Google Cloud per configurare e gestire le impostazioni dell'app. Cloud Run non richiede la configurazione basata su file, ma è supportata la configurazione YAML.
Ogni servizio di cui esegui il deployment su Cloud Run utilizza il dominio
run.appnell'URL per accedere pubblicamente al servizio.A differenza dei servizi App Engine che sono pubblici per impostazione predefinita, i servizi Cloud Run sono privati per impostazione predefinita e richiedono la configurazione per l'accesso pubblico (non autenticato).
Ruoli obbligatori
Puoi scegliere di creare un nuovo account di servizio o di utilizzare lo stesso account di servizio gestito dall'utente in Cloud Run che utilizzi per App Engine. Tu o il tuo amministratore dovete concedere all'account di deployment e al account di servizio Cloud Build i seguenti ruoli IAM.
Fai clic per visualizzare i ruoli richiesti per l'account di deployment
Per ottenere le autorizzazioni necessarie per compilare ed eseguire il deployment dal codice sorgente, chiedi all'amministratore di concederti i seguenti ruoli IAM:
- Cloud Run Source Developer (
roles/run.sourceDeveloper) sul tuo progetto - Service Usage Consumer (
roles/serviceusage.serviceUsageConsumer) sul tuo progetto - Service Account User (
roles/iam.serviceAccountUser) sull'identità di servizio Cloud Run
Fai clic per visualizzare i ruoli richiesti per il account di servizio Cloud Build
Cloud Build utilizza automaticamente l'account di servizio predefinito di Compute Engine come service account Cloud Build predefinito per creare il codice sorgente e la risorsa Cloud Run, a meno che tu non esegua l'override di questo comportamento. Per consentire a Cloud Build di creare le tue origini, chiedi all'amministratore di concedere il ruolo Cloud Run Builder (roles/run.builder) al account di servizio Compute Engine predefinito nel tuo progetto:
gcloud projects add-iam-policy-binding PROJECT_ID \ --member=serviceAccount:PROJECT_NUMBER-compute@developer.gserviceaccount.com \ --role=roles/run.builder
Sostituisci PROJECT_NUMBER con il numero del tuo progetto Google Cloude PROJECT_ID con l'ID progetto Google Cloud. Per istruzioni dettagliate su come trovare l'ID progetto e il numero di progetto,
vedi Creazione
e gestione dei progetti.
La concessione del ruolo Cloud Run Builder al account di servizio Compute Engine predefinito richiede alcuni minuti per la propagazione.
Per un elenco di ruoli e autorizzazioni IAM associati a Cloud Run, consulta Ruoli IAM di Cloud Run e Autorizzazioni IAM di Cloud Run. Se il tuo servizio Cloud Run interagisce con le APIGoogle Cloud , come le librerie client Cloud, consulta la guida alla configurazione dell'identità del servizio. Per saperne di più sulla concessione dei ruoli, consulta Autorizzazioni di deployment e Gestisci l'accesso.
Utilizzare il file app.yaml
Traduci il file app.yaml di App Engine in un servizio Cloud Run eseguendo questo comando:
gcloud beta app migrate-to-run --appyaml=PATH --entrypoint=ENTRYPOINT
Sostituisci quanto segue:
- PATH con il percorso del file
app.yaml. - ENTRYPOINT con il comando del punto di ingresso per la tua applicazione.
Se ti trovi nella directory del progetto, entrambi gli argomenti PATH e ENTRYPOINT sono
facoltativi.
Per ulteriori informazioni sugli argomenti che puoi utilizzare con il comando gcloud beta app migrate-to-run,
consulta gcloud beta app migrate-to-run.
Eseguire il deployment di un'applicazione App Engine esistente
Esegui il deployment di un'app App Engine esistente direttamente su Cloud Run eseguendo il comando seguente:
gcloud beta app migrate-to-run --service=SERVICE --version=VERSION --entrypoint=ENTRYPOINT
Questo comando ti chiede di specificare il percorso relativo alla directory del codice sorgente.
Sostituisci quanto segue:
- SERVICE con il nome del tuo servizio App Engine.
- VERSION con l'ID versione del tuo servizio.
- ENTRYPOINT con il comando del punto di ingresso per la tua applicazione. Se ti trovi nella directory del progetto, questo argomento è facoltativo.
Per ulteriori informazioni sugli argomenti che puoi utilizzare con il comando gcloud beta app migrate,
consulta gcloud beta app migrate-to-run.
Funzionalità non compatibili
Il comando di migrazione non va a buon fine se il file app.yaml contiene una delle seguenti configurazioni non supportate:
Servizi in entrata:
inbound_services: - warmupPagine di errore personalizzate:
error_handlers: - file: default_error.html - error_code: over_quota file: over_quota.htmlServizi in bundle per i runtime di seconda generazione:
app_engine_apis: trueVariabili di ambiente di build:
build_env_variables: Foo: BarRuntime di prima generazione:
runtime: python27
Passaggi successivi
- Scopri come gestire i servizi Cloud Run.
- Consulta il contratto di runtime del container di Cloud Run per comprendere i requisiti e i comportamenti dei container in Cloud Run.
- Scopri come archiviare le dipendenze per il tuo servizio che richiede chiavi API, password o altre informazioni sensibili utilizzando Secret Manager.