Déployer une application conteneurisée sur Cloud Run à l'aide de Cloud Build

Cette page vous explique comment utiliser Cloud Build pour déployer une application conteneurisée dans Cloud Run.


Pour obtenir des instructions détaillées sur cette tâche directement dans l'éditeur Cloud Shell, cliquez sur Visite guidée :

Visite guidée


Avant de commencer

  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. Make sure that billing is enabled for your Google Cloud project.

  4. Enable the Cloud Build, Cloud Run, Artifact Registry, and Compute Engine APIs.

    Enable the APIs

  5. Install the Google Cloud CLI.
  6. To initialize the gcloud CLI, run the following command:

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

    Go to project selector

  8. Make sure that billing is enabled for your Google Cloud project.

  9. Enable the Cloud Build, Cloud Run, Artifact Registry, and Compute Engine APIs.

    Enable the APIs

  10. Install the Google Cloud CLI.
  11. To initialize the gcloud CLI, run the following command:

    gcloud init

Octroyer des autorisations

Cloud Build requiert les autorisations Administrateur Cloud Run et Utilisateur du compte de service IAM avant de pouvoir déployer une image dans Cloud Run.

  1. Ouvrez une fenêtre de terminal.

  2. Définissez les variables d'environnement pour stocker l'ID et le numéro de votre projet :

    PROJECT_ID=$(gcloud config list --format='value(core.project)')
    PROJECT_NUMBER=$(gcloud projects describe $PROJECT_ID --format='value(projectNumber)')
    
  3. Accordez le rôle Administrateur Cloud Run au compte de service Cloud Build :

    gcloud projects add-iam-policy-binding $PROJECT_ID \
        --member=serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com \
        --role=roles/run.admin
    
  4. Attribuez le rôle Utilisateur du compte de service IAM au compte de service Cloud Build sur le compte de service d'exécution Cloud Run :

    gcloud iam service-accounts add-iam-policy-binding \
        $PROJECT_NUMBER-compute@developer.gserviceaccount.com \
        --member=serviceAccount:$PROJECT_NUMBER@cloudbuild.gserviceaccount.com \
        --role=roles/iam.serviceAccountUser
    

Déployer une image prédéfinie

Vous pouvez configurer Cloud Build pour qu'il déploie une image prédéfinie stockée dans Artifact Registry dans Cloud Run.

Pour déployer une image prédéfinie, procédez comme suit :

  1. Ouvrez une fenêtre de terminal (si aucune n'est déjà ouverte).

  2. Créez un répertoire nommé helloworld et accédez-y :

    mkdir helloworld
    cd helloworld
    
  3. Créez un fichier nommé cloudbuild.yaml avec le contenu suivant : Il s'agit du fichier de configuration de Cloud Build. Il contient des instructions permettant à Cloud Build de déployer l'image nommée us-docker.pkg.dev/cloudrun/container/hello sur le service Cloud Run nommé cloudrunservice.

    steps:
    - name: 'gcr.io/cloud-builders/gcloud'
      script: |
        gcloud run deploy cloudrunservice --image us-docker.pkg.dev/cloudrun/container/hello --region us-central1 --platform managed --allow-unauthenticated
  4. Déployez l'image en exécutant la commande suivante :

    gcloud builds submit --region=us-west2 --config cloudbuild.yaml
    

Une fois la compilation terminée, un résultat semblable aux lignes suivantes doit s'afficher :

DONE
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

ID                                    CREATE_TIME                DURATION  SOURCE                                                                                            IMAGES  STATUS
784653b2-f00e-4c4b-9f5f-96a5f115bef4  2020-01-23T14:53:13+00:00  23S       gs://cloudrunqs-project_cloudbuild/source/1579791193.217726-ea20e1c787fb4784b19fb1273d032df2.tgz  -       SUCCESS

Vous venez de déployer l'image hello dans Cloud Run.

Exécuter l'image déployée

  1. Ouvrez la page Cloud Run dans la console Google Cloud :

    Ouvrez la page Cloud Run

  2. Sélectionnez votre projet et cliquez sur Ouvrir.

    La page Services Cloud Run s'affiche.

  3. Dans le tableau, recherchez la ligne portant le nom cloudrunservice, puis cliquez sur cloudrunservice.

    La page Informations sur le service de cloudrunservice s'affiche.

  4. Pour exécuter l'image que vous avez déployée sur cloudrunservice, cliquez sur l'URL :

    Capture d'écran de la page des services Cloud Run

Étape suivante