Maison > développement back-end > Golang > Comment diffuser la sortie d'une commande en temps réel vers le processus parent et le fichier journal ?

Comment diffuser la sortie d'une commande en temps réel vers le processus parent et le fichier journal ?

Linda Hamilton
Libérer: 2024-12-15 07:26:13
original
805 Les gens l'ont consulté

How to Stream Real-time Command Output to Parent Process and Log File?

Commandes en streaming : afficher la progression en temps réel

Dans ce scénario, vous souhaitez diffuser la sortie d'une commande exécutée à la fois vers le processus parent et vers un journal déposer. Cependant, le standard cmd.StdoutPipe renvoie le résultat final sous forme de chaîne, ce qui devient une limitation pour les processus de longue durée.

Exploration de la solution

Le code fourni, qui utilise exec.Command, StdoutPipe et bufio.NewScanner fonctionnent comme prévu. Il diffuse efficacement la sortie du processus enfant, l'imprime sur la console et l'enregistre en temps réel. La sortie en direct du processus enfant est capturée et affichée au fur et à mesure.

Conseils de dépannage

Si le code ne fonctionne pas pour vous, considérez les raisons suivantes :

  • Nouvelles lignes manquantes : Le bufio.NewScanner lit des lignes entières, ne renvoyant des données que lorsqu'il rencontre des caractères de nouvelle ligne. Si la commande n'imprime pas les nouvelles lignes, la sortie peut ne pas être diffusée immédiatement.
  • Tampon de sortie de commande : Les processus ont des tailles de tampon par défaut pour stdout et stderr. Si le tampon est rempli et n'est pas lu, le processus enfant peut se bloquer en raison d'un blocage des écritures. Par conséquent, lisez toujours stdout et stderr pour éviter ce problème.

Solutions de contournement possibles

Si la commande n'imprime pas les nouvelles lignes, il existe des méthodes alternatives pour diffuser la sortie :

  • Lecture par mots : Définissez la fonction de division du scanner sur bufio.ScanWords pour lire des mots individuels au lieu de lignes.
  • Lecture par caractères : Définissez la fonction de division du scanner sur bufio.ScanRunes pour lire les caractères un par un.
  • Lecture manuelle : Lisez la sortie standard octet par octet ou rune par rune, en vous assurant que l'encodage UTF-8 est géré correctement.

Il est important de se rappeler que si le processus enfant écrit dans ses flux stdout et stderr par défaut, ils seront ignorés à moins qu'ils ne soient explicitement lus. La lecture de ces flux garantit que vous ne manquerez aucun message de sortie ou d'erreur, même si le processus enfant ne génère généralement pas de sortie vers ces flux.

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal