Détection des boucles d’outils
OpenClaw peut empêcher les agents de rester bloqués dans des schémas répétés d’appels d’outils. Cette protection est désactivée par défaut. Activez-la uniquement là où c’est nécessaire, car elle peut bloquer des appels répétés légitimes avec des paramètres stricts.Pourquoi cela existe
- Détecter des séquences répétitives qui ne progressent pas.
- Détecter des boucles à haute fréquence sans résultat (même outil, mêmes entrées, erreurs répétées).
- Détecter des schémas spécifiques d’appels répétés pour des outils de polling connus.
Bloc de configuration
Valeurs par défaut globales :Comportement des champs
enabled: commutateur principal.falsesignifie qu’aucune détection de boucle n’est effectuée.historySize: nombre d’appels d’outils récents conservés pour l’analyse.warningThreshold: seuil avant de classer un schéma comme simple avertissement.criticalThreshold: seuil à partir duquel les schémas répétitifs de boucle sont bloqués.globalCircuitBreakerThreshold: seuil global du coupe-circuit en cas d’absence de progression.detectors.genericRepeat: détecte les schémas répétés même-outil + mêmes-paramètres.detectors.knownPollNoProgress: détecte les schémas de type polling connus sans changement d’état.detectors.pingPong: détecte les schémas alternés de ping-pong.
Configuration recommandée
- Commencez avec
enabled: true, sans modifier les valeurs par défaut. - Conservez les seuils dans l’ordre
warningThreshold < criticalThreshold < globalCircuitBreakerThreshold. - Si des faux positifs apparaissent :
- augmentez
warningThresholdet/oucriticalThreshold - (facultativement) augmentez
globalCircuitBreakerThreshold - désactivez uniquement le détecteur à l’origine du problème
- réduisez
historySizepour un contexte historique moins strict
- augmentez
Journaux et comportement attendu
Lorsqu’une boucle est détectée, OpenClaw signale un événement de boucle et bloque ou atténue le cycle d’outil suivant selon la gravité. Cela protège les utilisateurs contre une consommation incontrôlée de tokens et les blocages tout en préservant l’accès normal aux outils.- Préférez d’abord l’avertissement et la suppression temporaire.
- N’escaladez que lorsque des preuves répétées s’accumulent.
Notes
tools.loopDetectionest fusionné avec les remplacements au niveau de l’agent.- La configuration par agent remplace entièrement ou étend les valeurs globales.
- Si aucune configuration n’existe, les garde-fous restent désactivés.