Gérer les erreurs avec un prédicat personnalisé
Restez organisé à l'aide des collections
Enregistrez et classez les contenus selon vos préférences.
Définit un gestionnaire d'erreurs personnalisé, y compris un prédicat personnalisé et des paramètres d'intervalle entre les tentatives personnalisé.
En savoir plus
Pour obtenir une documentation détaillée incluant cet exemple de code, consultez les articles suivants :
Exemple de code
Sauf indication contraire, le contenu de cette page est régi par une licence Creative Commons Attribution 4.0, et les échantillons de code sont régis par une licence Apache 2.0. Pour en savoir plus, consultez les Règles du site Google Developers. Java est une marque déposée d'Oracle et/ou de ses sociétés affiliées.
[[["Facile à comprendre","easyToUnderstand","thumb-up"],["J'ai pu résoudre mon problème","solvedMyProblem","thumb-up"],["Autre","otherUp","thumb-up"]],[["Difficile à comprendre","hardToUnderstand","thumb-down"],["Informations ou exemple de code incorrects","incorrectInformationOrSampleCode","thumb-down"],["Il n'y a pas l'information/les exemples dont j'ai besoin","missingTheInformationSamplesINeed","thumb-down"],["Problème de traduction","translationIssue","thumb-down"],["Autre","otherDown","thumb-down"]],[],[],[],null,["# Handle errors with custom predicate\n\nDefines a custom error handler, including a custom predicate and custom backoff parameters.\n\nExplore further\n---------------\n\n\nFor detailed documentation that includes this code sample, see the following:\n\n- [Retry steps](/workflows/docs/reference/syntax/retrying)\n\nCode sample\n-----------\n\n### YAML\n\n # Define a custom error handler, custom predicate, and custom backoff parameters\n # The `my_own_predicate` subworkflow accepts a map as an argument and defines the\n # exception; it returns true if a retry; false, otherwise\n # Expected outcome: the execution fails and returns an HTTP 404 Not Found error\n main:\n steps:\n - read_item:\n try:\n call: http.get\n args:\n url: https://example.com/someapi\n result: api_response\n retry:\n predicate: ${my_own_predicate}\n max_retries: 5\n backoff:\n initial_delay: 2\n max_delay: 60\n multiplier: 2\n - last_step:\n return: \"OK\"\n\n my_own_predicate:\n params: [e]\n steps:\n - log_error_tags:\n call: sys.log\n args:\n data: ${e.tags}\n severity: \"INFO\"\n - log_error_message:\n call: sys.log\n args:\n data: ${e.message}\n severity: \"INFO\"\n - log_error_code:\n call: sys.log\n args:\n data: ${e.code}\n severity: \"INFO\"\n - what_to_repeat:\n switch:\n - condition: ${e.code == 202}\n return: true\n - otherwise:\n return: false\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=workflows)."]]