Lors de l'exécution de code dans un conteneur Docker, les utilisateurs peuvent rencontrer des cas où la mise en mémoire tampon stdout se produit, provoquant le vidage des sorties par intermittence plutôt que leur apparition. immédiatement après la génération. Ce phénomène peut varier en fonction du système d'exploitation du conteneur et du code lui-même.
Dans un cas particulier, le problème s'est manifesté lors de l'exécution du programme "procwrap" dans un conteneur Docker. Alors que le sous-processus s'exécutait avec succès, la sortie vers la sortie standard et les fichiers journaux apparaissait en rafales, indiquant une réponse mise en mémoire tampon. Cependant, l'exécution du même code en dehors d'un conteneur entraînait une sortie synchrone.
Enquête et dépannage
Les premières observations ont révélé que le problème était lié à la mise en mémoire tampon de la sortie standard. Les modifications des paramètres Docker ou Linux (telles que l'utilisation de "stdbuf") se sont révélées inefficaces pour résoudre le problème.
Solution
Pour surmonter ce défi, des modifications ont été apportées au code source de l’application console en cours de conteneurisation. Ces modifications ont forcé un vidage immédiat du fichier après chaque opération d'écriture. Cela garantissait que les données n'étaient pas mises en mémoire tampon dans l'application et étaient sorties en temps réel.
Considérations supplémentaires
La configuration spécifique utilisée pour résoudre ce problème impliquait une journalisation personnalisée qui écrivait vers "/dev/stdout" et déclenché le vidage du fichier à chaque écriture du journal. Cela a permis au conteneur Docker d'afficher des messages immédiatement via la commande "docker logs".
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!