Ce document explique comment activer, générer et afficher les journaux de Cloud Logging pour un job Batch.
Vous pouvez utiliser les journaux pour obtenir des informations utiles pour analyser vos jobs. Par exemple, les journaux peuvent vous aider à déboguer les tâches ayant échoué.
Notez que les journaux ne sont générés qu'après le démarrage d'une tâche et uniquement si la journalisation a été activée pour cette tâche. Si vous devez analyser un job sans journaux, affichez plutôt les événements d'état.
Avant de commencer
- Si vous n'avez jamais utilisé Batch, consultez Premiers pas avec Batch et activez Batch en remplissant les conditions préalables pour les projets et les utilisateurs.
-
Pour obtenir les autorisations nécessaires pour analyser un job à l'aide des journaux, demandez à votre administrateur de vous accorder les rôles IAM suivants :
-
Pour créer un job :
-
Éditeur de tâches par lot (
roles/batch.jobsEditor
) sur le projet -
Utilisateur du compte de service (
roles/iam.serviceAccountUser
) sur le compte de service du job, qui est par défaut le compte de service Compute Engine par défaut
-
Éditeur de tâches par lot (
-
Pour afficher les journaux :
Lecteur de journaux (
roles/logging.viewer
) sur le projet
Pour en savoir plus sur l'attribution de rôles, consultez Gérer l'accès aux projets, aux dossiers et aux organisations.
Vous pouvez également obtenir les autorisations requises avec des rôles personnalisés ou d'autres rôles prédéfinis.
-
Pour créer un job :
Activer la journalisation pour un job
Pour autoriser la génération de journaux pour un job, activez les journaux à partir de Cloud Logging lorsque vous créez le job :
- Si vous créez un job à l'aide de la console Google Cloud , les journaux de Cloud Logging sont toujours activés.
Si vous créez un job à l'aide de gcloud CLI ou de l'API Batch, les journaux de Cloud Logging sont désactivés par défaut. Pour activer les journaux de Cloud Logging, incluez la configuration suivante pour le champ
logsPolicy
lors de la création du job :{ ... "logsPolicy": { "destination": "CLOUD_LOGGING" } ... }
Écrire et générer des journaux pour un job
Lorsque les journaux Cloud Logging sont activés pour un job, Cloud Logging génère automatiquement tous les journaux écrits pour le job. Plus précisément, les jobs par lot peuvent avoir les types de journaux suivants :
Journaux de l'agent (
batch_agent_logs
) : journaux des activités de l'agent de service Batch.Batch écrit automatiquement les journaux d'agent pour chaque job dont la journalisation est activée.
Journaux des tâches (
batch_task_logs
) : journaux de toutes les données pour lesquelles vous avez configuré les exécutables d'un job afin qu'ils écrivent dans le flux de sortie standard (stdout
) ou le flux d'erreur standard (stderr
).Vous pouvez éventuellement écrire des journaux de tâches pour chaque job pour lequel la journalisation est activée.
Afficher les journaux d'un job
Vous pouvez afficher les journaux d'un job à l'aide de la console Google Cloud , de gcloud CLI, de l'API Logging, de Go, de Java, de Python ou de C++.
Console
Pour afficher les journaux d'un job à l'aide de la console Google Cloud , procédez comme suit :
Dans la console Google Cloud , accédez à la page Liste des jobs.
Dans la colonne Nom du job, cliquez sur le nom d'un job. La page Job details (Informations sur le job) s'ouvre.
Cliquez sur l'onglet Journaux. Batch affiche tous les journaux associés au job.
Facultatif : Pour filtrer les journaux, effectuez l'une des opérations suivantes :
Saisissez un filtre dans le champ Filtre.
Dans la liste Gravité, sélectionnez une gravité.
Cliquez sur créer une requête dans l'explorateur de journaux à l'aide des paramètres de filtre de lot.
Afficher dans l'explorateur de journaux pour
gcloud
Pour afficher les journaux à l'aide de gcloud CLI, exécutez la commande gcloud logging read
:
gcloud logging read "QUERY"
où QUERY
est une requête pour les journaux de traitement par lot qui contient des paramètres de filtrage par lot.
API
Pour afficher les journaux à l'aide de l'API Logging, utilisez la méthode entries.list
:
POST https://logging.googleapis.com/v2/entries:list
{
"resourceNames": [
"projects/PROJECT_ID"
],
"filter": "QUERY"
"orderBy": "timestamp desc"
}
Remplacez les éléments suivants :
PROJECT_ID
: ID de projet de votre projet.QUERY
: requête pour les journaux par lots contenant les paramètres de filtre par lots.
Go
Go
Pour en savoir plus, consultez la documentation de référence de l'API Batch Go.
Pour vous authentifier auprès de Batch, configurez les Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Java
Java
Pour en savoir plus, consultez la documentation de référence de l'API Batch Java.
Pour vous authentifier auprès de Batch, configurez les Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Python
Python
Pour en savoir plus, consultez la documentation de référence de l'API Batch Python.
Pour vous authentifier auprès de Batch, configurez les Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
C++
C++
Pour en savoir plus, consultez la documentation de référence de l'API Batch C++.
Pour vous authentifier auprès de Batch, configurez les Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Filtrer les journaux de traitement par lot
Vous pouvez filtrer les journaux par lot en écrivant une requête qui inclut un ou plusieurs des paramètres de filtre suivants, ainsi que zéro ou plusieurs opérateurs booléens (AND
, OR
et NOT
).
Pour filtrer les journaux d'un job spécifique, indiquez son ID unique (UID) :
labels.job_uid=JOB_UID
où
JOB_UID
est l'UID du job. Pour obtenir l'UID d'un job, affichez ses détails.Pour filtrer un type spécifique de journaux par lots, spécifiez le type de journal :
logName=projects/PROJECT_ID/logs/BATCH_LOG_TYPE
Remplacez les éléments suivants :
PROJECT_ID
: ID du projet pour lequel vous souhaitez afficher les journaux.BATCH_LOG_TYPE
: type de journaux Batch que vous souhaitez afficher (batch_task_logs
pour les journaux de tâches oubatch_agent_logs
pour les journaux d'agent).
Pour filtrer les journaux avec des événements d'état personnalisés, spécifiez que le journal doit définir le champ
jsonPayload.batch/custom/event
:jsonPayload.batch"/"custom"/"event!=NULL_VALUE
Pour filtrer les journaux d'un ou de plusieurs niveaux de gravité spécifiques, spécifiez la comparaison suivante :
severityCOMPARISON_OPERATORSEVERITY_ENUM
Remplacez les éléments suivants :
COMPARISON_OPERATOR
: opérateur de comparaison (par exemple,>=
)SEVERITY_ENUM
: enumLogSeverity
, qui décrit la gravité d'un journal (par exemple,ERROR
).
Pour découvrir d'autres options de filtrage, consultez la documentation sur le langage de requête Cloud Logging.
Étapes suivantes
- En savoir plus sur le dépannage
- Apprenez-en plus sur Cloud Logging.
- Découvrez comment écrire des journaux de tâches.
- Découvrez comment exporter des informations sur les tâches.
- Découvrez comment supprimer des jobs.