- Orchestration de conteneurs : pods susceptibles d’être évincés ou arrêtés faute de mémoire avant que les threads d’arrière-plan aient fini de téléverser les traces.
- Entraînement distribué : plusieurs processus écrivent des traces en parallèle, et l’un d’eux peut échouer.
- Réseaux peu fiables : environnements où la connectivité au serveur Weave est intermittente.
- Tâches par lots : tâches de longue durée pour lesquelles la perte de données de trace à la suite d’un plantage est coûteuse.
weave.flush() ou weave.finish() avant la fin du processus afin de vous assurer que toutes les données sont téléversées. Pour plus d’informations, voir Perte de données de trace dans les processus worker.
Le journal à écriture anticipée doit être activé explicitement. Il sera activé par défaut dans une future version.
Activer le journal à écriture anticipée
WEAVE_ENABLE_WAL sur true :
weave.init() :
Fonctionnement
- Weave ajoute chaque appel à l’API Weave (création d’objet, début d’appel, fin d’appel, etc.) à un fichier JSONL sur disque au lieu de le conserver uniquement en mémoire.
- Chaque processus écrit dans son propre fichier journal, afin que les processus parallèles n’entrent pas en conflit.
- Un processus d’envoi en arrière-plan lit les fichiers journaux et effectue le vidage de leur contenu vers le serveur Weave.
- Une fois les données envoyées avec succès, Weave supprime le fichier journal.
.weave/wal/ dans votre répertoire de travail, organisés par entité et par projet. Chaque fichier contient les requêtes API brutes sous forme d’objets JSON, à raison d’un objet par ligne.
Au démarrage du client, celui-ci vérifie s’il existe des fichiers journaux issus d’exécutions précédentes. S’il en trouve, le processus d’envoi en effectue le vidage avec les nouvelles données. Cela signifie que Weave récupère automatiquement, au prochain démarrage du client, les données écrites par un processus qui a planté.
Variables d’environnement
| Variable | Type | Default | Description |
|---|---|---|---|
WEAVE_ENABLE_WAL | bool | false | Active le journal à écriture anticipée. Lorsqu’elle est définie sur true, Weave écrit les requêtes API localement sur le disque avant de les envoyer au serveur. |
WEAVE_DISABLE_WAL_SENDER | bool | false | Désactive l’expéditeur WAL. Lorsqu’elle est définie sur true, Weave écrit les requêtes localement sur le disque, mais n’effectue pas leur vidage vers le serveur. C’est utile pour le débogage. |