Dans ce document, vous utilisez les composants facturables suivants de Google Cloud :
- Dataproc
- Compute Engine
- Cloud Scheduler
Obtenez une estimation des coûts en fonction de votre utilisation prévue à l'aide du simulateur de coût.
Avant de commencer
Configurer votre projet
- 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 Dataproc, Compute Engine, and Cloud Scheduler APIs.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
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 Dataproc, Compute Engine, and Cloud Scheduler APIs.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
Créer un rôle personnalisé
- Ouvrez la page IAM et administration → Rôles dans la console Google Cloud .
- Cliquez sur CRÉER UN RÔLE pour ouvrir la page Créer un rôle.
- Renseignez les champs "Titre", "Description", "ID" et "Étape de lancement". Suggestion : utilisez "Créer un modèle de workflow Dataproc" comme titre de rôle.
- Cliquez sur AJOUTER DES AUTORISATIONS.
- Dans le formulaire Ajouter des autorisations, cliquez sur Filtrer, puis sélectionnez "Autorisation". Complétez le filtre pour afficher "Permission: dataproc.workflowTemplates.instantiate".
- Cochez la case située à gauche de l'autorisation répertoriée, puis cliquez sur ADD (Ajouter).
- Sur la page "Créer un rôle", cliquez à nouveau sur "Ajouter des autorisations" pour répéter les sous-étapes précédentes afin d'ajouter l'autorisation "iam.serviceAccounts.actAs" au rôle personnalisé. La page Créer un rôle répertorie désormais deux autorisations.
- Cliquez sur CREATE (Créer) sur la page Custom Role (Rôle personnalisé). Le rôle personnalisé est répertorié sur la page Roles (Rôles).
Créer un compte de service
Dans la console Google Cloud , accédez à la page Comptes de service.
Sélectionnez votre projet.
Cliquez sur
+ Create service account (+ Créer un compte de service).Dans le champ Nom du compte de service, saisissez le nom
workflow-scheduler
. La console Google Cloud remplit le champ ID du compte de service en fonction de ce nom.Facultatif : dans le champ Description du compte de service, saisissez une description du compte de service.
Cliquez sur Créer et continuer.
Cliquez sur le champ Sélectionner un rôle, puis choisissez le rôle personnalisé Création de modèles de workflow Dataproc que vous avez créé à l'étape précédente.
Cliquez sur Continuer.
Dans le champ Rôle d'administrateur du compte de service, saisissez l'adresse e-mail de votre compte Google.
Cliquez sur OK pour terminer la création du compte de service.
Créer un modèle de workflow
Copiez et exécutez les commandes répertoriées ci-dessous dans une fenêtre de terminal local ou dans Cloud Shell pour créer et définir un modèle de workflow.
Notes :
- Les commandes spécifient la région "us-central1". Vous pouvez spécifier une autre région ou supprimer l'option
--region
si vous avez déjà exécutégcloud config set compute/region
pour définir la propriété de région. - La séquence "-- " (tiret, tiret, espace) de la commande
add-job
transmet l'argument1000
à la tâche SparkPi qui spécifie le nombre d'échantillons à utiliser pour estimer la valeur de Pi.
- Créez le modèle de workflow.
gcloud dataproc workflow-templates create sparkpi \ --region=us-central1
- Ajoutez la tâche spark au modèle de workflow sparkpi. L'ID d'étape "compute" est requis et identifie la tâche SparkPi ajoutée.
gcloud dataproc workflow-templates add-job spark \ --workflow-template=sparkpi \ --step-id=compute \ --class=org.apache.spark.examples.SparkPi \ --jars=file:///usr/lib/spark/examples/jars/spark-examples.jar \ --region=us-central1 \ -- 1000
- Utilisez un cluster géré à nœud unique pour exécuter le workflow. Dataproc crée le cluster, y exécute le workflow, puis le supprime une fois le workflow terminé.
gcloud dataproc workflow-templates set-managed-cluster sparkpi \ --cluster-name=sparkpi \ --single-node \ --region=us-central1
- Cliquez sur le nom
sparkpi
sur la page Workflows Dataproc dans la console Google Cloud pour ouvrir la page Détails du modèle de workflow. Confirmez les attributs du modèle sparkpi.
Créer une tâche Cloud Scheduler
Ouvrez la page Cloud Scheduler dans la consoleGoogle Cloud (vous devrez peut-être sélectionner votre projet pour ouvrir la page). Cliquez sur CRÉER UNE TÂCHE.
Saisissez ou sélectionnez les informations suivantes sur la tâche :
- Sélectionnez une région : "us-central" ou toute autre région dans laquelle vous avez créé votre modèle de workflow.
- Nom : "Sparkpi"
- Fréquence : sélectionnez "* * * *" pour une exécution toutes les minutes, sélectionnez "0 9 * * 1" pour une exécution tous les lundis à 9 heures. Consultez la page Définir le calendrier de tâche pour les autres valeurs unix-cron. Remarque:Vous pourrez cliquer sur le bouton "EXÉCUTER MAINTENANT" des Tâches Cloud Scheduler dans la console Google Cloud pour exécuter et tester une tâche, quelle que soit la fréquence que vous définissez.
- Fuseau horaire : sélectionnez un fuseau (timezone). Saisissez "United States" (États-Unis) pour répertorier les fuseaux horaires américains.
- Cible : "HTTP"
- URL : insérez l'URL suivante après avoir spécifié your-project-id. Si vous avez créé votre modèle de workflow dans une région autre que "us-central1", remplacez cet élément. Cette URL appelle l'API Dataproc
workflowTemplates.instantiate
pour exécuter votre modèle de workflow Sparkpi.https://dataproc.googleapis.com/v1/projects/your-project-id/regions/us-central1/workflowTemplates/sparkpi:instantiate?alt=json
- Méthode HTTP :
- "POST"
- Corps : "{}"
- En-tête d'authentification :
- "Ajouter un jeton OAuth"
- Compte de service : insérez le paramètre service account address du compte de service que vous avez créé pour ce tutoriel.
Vous pouvez utiliser l'adresse de compte suivante après avoir inséré your-project-id :
workflow-scheduler@your-project-id.iam.gserviceaccount.com
- Champ d'application : vous pouvez ignorer ce champ.
- Cliquez sur CREATE (Créer).
Tester une tâche de workflow planifiée
Sur la ligne de la tâche
sparkpi
de la page Tâches Cloud Scheduler, cliquez sur "Exécuter".Attendez quelques minutes, puis ouvrez la page Workflows Dataproc pour vérifier si le workflow sparkpi est terminé.
Une fois que le workflow a supprimé le cluster géré, les détails de la tâche persistent dans la console Google Cloud . Cliquez sur la tâche
compute...
répertoriée sur la page Tâches Dataproc pour afficher les détails de la tâche de workflow.
Nettoyer
Une fois terminé, le workflow de ce tutoriel supprime son cluster géré. Le fait de conserver le workflow vous permet de le relancer sans frais supplémentaires. Vous pouvez supprimer les autres ressources créées dans ce tutoriel pour éviter des coûts récurrents.
Supprimer un projet
- 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.
Supprimer votre modèle de workflow
gcloud dataproc workflow-templates delete sparkpi \ --region=us-central1
Supprimer une tâche Cloud Scheduler
Dans la console Google Cloud , ouvrez la page Tâches Cloud Scheduler, cochez la case située à gauche de la fonction sparkpi
, puis cliquez sur "SUPPRIMER".
Supprimer un compte de service
Dans la console Google Cloud , ouvrez la page IAM et administration → Comptes de service, cochez la case située à gauche du compte de service workflow-scheduler...
, puis cliquez sur SUPPRIMER.
Étape suivante
- Consultez la page Présentation des modèles de workflow Dataproc.
- Consultez la page Solutions de planification de workflow