Ajouter une tâche App Engine à une file d'attente Cloud Tasks
Ce guide de démarrage rapide explique comment ajouter une tâche App Engine à une file d'attente Cloud Tasks à l'aide de l'API Cloud Tasks.
Avant de commencer
- 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.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Resource Manager and Cloud Tasks API:
gcloud services enable cloudresourcemanager.googleapis.com tasks.googleapis.com
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Resource Manager and Cloud Tasks API:
gcloud services enable cloudresourcemanager.googleapis.com tasks.googleapis.com
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
- Le compte de service App Engine par défaut est créé automatiquement lorsque vous utilisez App Engine. Vous pouvez utiliser cette
compte de service lorsque vous essayez ce guide de démarrage rapide. Toutefois, selon la configuration de vos règles d'administration, le compte de service par défaut peut ne pas se voir attribuer automatiquement le rôle
Editor
sur votre projet. Si tel est le cas, vous devez accorder au compte de service les rôles suivants:- Administrateur Artifact Registry (
roles/artifactregistry.admin
) - Rédacteur de dépôt Artifact Registry avec création lors de l'envoi (
roles/artifactregistry.createOnPushWriter
) - Administrateur de Compute (
roles/compute.admin
) - Rédacteur de journaux (
roles/logging.logWriter
) - Lecteur des objets de l'espace de stockage (
roles/storage.objectViewer
)
- Administrateur Artifact Registry (
Ajouter une application App Engine
Lorsque vous ciblez une tâche App Engine, et avant de déployer une application sur l'environnement standard App Engine, vous devez ajouter Application App Engine à votre projet.
Dans la console Google Cloud, accédez à la page App Engine.
Dans la boîte de dialogue Welcome to App Engine (Bienvenue dans App Engine), effectuez l'une des opérations suivantes:
Si vous avez déjà créé une application App Engine et qu'il existe un Your App Engine application has been created (Votre application App Engine a été créée) s'affiche, vous pouvez puis ignorez les étapes restantes de cette section et passez aux étapes décrites dans consultez la section Installer et déployer l'exemple.
ou
Si vous n'avez pas encore créé d'application App Engine, cliquez sur Créez une application et passez aux étapes restantes de cette section.
Sélectionnez une région pour votre application et notez-la.
Notez que
europe-west
etus-central
sont appelés respectivementeurope-west1
etus-central1
dans les commandes Cloud Tasks.Ne sélectionnez pas de compte de service. le service App Engine par défaut est utilisé.
Cliquez sur Suivant.
L'application est configurée et créée. Cette opération peut prendre quelques minutes.
Ne téléchargez pas Cloud SDK. cliquez sur Je le ferai plus tard.
Le message Votre application App Engine a bien été créée devrait s'afficher.
Installer et déployer l'exemple
L'exemple Node.js utilisé dans ce guide de démarrage rapide comprend deux fichiers:
createTask.js
est exécuté localement en tant qu'outil de ligne de commande pour créer et ajouter des tâches à
la file d'attente Tasks ; server.js
est déployé sur App Engine en tant que
un service de nœuds de calcul
pour traiter la tâche.
Dans votre terminal, clonez le dépôt de l'exemple d'application dans votre environnement machine.
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples.git
Accédez au répertoire qui contient l'exemple de code.
cd nodejs-docs-samples/cloud-tasks/snippets
Installez toutes les dépendances à l'aide d'un gestionnaire de paquets Node.js.
Vous pouvez utiliser NPM :
npm install
Vous pouvez également utiliser Yarn :
yarn install
Déployez le service de nœuds de calcul (
server.js
) dans l'environnement standard App Engine.gcloud app deploy app.yaml
Assurez-vous que l'application contenant le service est en cours d'exécution.
gcloud app browse
Dans votre navigateur, accédez au lien fourni. Exemple :
https://PROJECT_ID.uc.r.appspot.com/
Hello, World!
devrait s'afficher.
Créer une file d'attente Cloud Tasks
Utilisez le gcloud tasks queues create
pour créer votre file d'attente dans l'environnement que vous avez préparé.
Dans votre terminal, créez une file d'attente qui consigne toutes les opérations.
gcloud tasks queues create QUEUE_NAME \ --log-sampling-ratio=1.0 \ --location=REGION
Remplacez les éléments suivants :
QUEUE_NAME
: nom de votre file d'attente Cloud TasksREGION
: région dans laquelle vous avez déployé votre application
Attendez que la file d'attente s'initialise, puis vérifiez qu'elle a bien été créée. avec succès.
gcloud tasks queues describe QUEUE_NAME \ --location=REGION
La sortie devrait ressembler à ce qui suit :
name: projects/PROJECT_ID/locations/LOCATION_ID/queues/QUEUE_NAME rateLimits: maxBurstSize: 100 maxConcurrentDispatches: 1000 maxDispatchesPerSecond: 500.0 retryConfig: maxAttempts: 100 maxBackoff: 3600s maxDoublings: 16 minBackoff: 0.100s state: RUNNING
Ajouter une tâche à la file d'attente Cloud Tasks
Créez une tâche, ajoutez-la à la file d'attente que vous avez créée, puis transmettez-la au service de nœud de calcul.
Définissez les variables d'environnement suivantes. Le client utilise ces informations pour créer la requête.
export PROJECT_ID=PROJECT_ID export LOCATION_ID=REGION export QUEUE_ID=QUEUE_NAME
Créez une tâche avec la charge utile
hello
et ajoutez cette tâche à la file d'attente. La charge utile peut être n'importe quelle donnée de la requête dont le service de nœud de calcul a besoin pour traiter la tâche.node createTask.js $PROJECT_ID $QUEUE_ID $LOCATION_ID hello
Vérifiez que la tâche a bien été exécutée en affichant les journaux du service de nœud de calcul.
gcloud app logs read
Les journaux doivent ressembler à ceci :
2024-06-20 15:00:00 default[20240620t143852] "POST /log_payload HTTP/1.1" 200 2024-06-20 15:00:00 default[20240620t143852] App listening on port 8081 2024-06-20 15:00:00 default[20240620t143852] Press Ctrl+C to quit. 2024-06-20 15:00:00 default[20240620t143852] Received task with payload: hello
Effectuer un nettoyage
Pour éviter que les ressources utilisées sur cette page ne soient facturées sur votre compte Google Cloud, supprimez le projet Google Cloud contenant les ressources.
Delete a Google Cloud project:
gcloud projects delete PROJECT_ID
Vous pouvez également supprimer les ressources que vous avez créées :
Supprimez la file d'attente Cloud Tasks :
gcloud tasks queues delete QUEUE_NAME \ --location=REGION