Maison >développement back-end >Golang >Comment rediriger la sortie Exec vers une connexion Go ?

Comment rediriger la sortie Exec vers une connexion Go ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-06 14:36:02476parcourir

How to Redirect Exec Output to a Log in Go?

Copie de la sortie Exec pour se connecter à Go

Dans Go, rediriger la sortie d'un processus de longue durée ou non terminé vers un journal peut être un défi. Même si l'attente de la fin du processus permet une capture simple des résultats, la journalisation en temps réel dans les environnements non terminaux nécessite une approche différente.

Une solution consiste à créer un canal pour connecter la sortie standard du processus à un scanner mis en mémoire tampon :

stdout, err := cmd.StdoutPipe()
if err != nil {
    return 0, err
}

// start the command after having set up the pipe
if err := cmd.Start(); err != nil {
    return 0, err
}

// read command's stdout line by line
in := bufio.NewScanner(stdout)

for in.Scan() {
    log.Printf(in.Text()) // write each line to your log, or anything you need
}
if err := in.Err(); err != nil {
    log.Printf("error: %s", err)
}

Ce code crée un tube stdout, démarre la commande, puis utilise un scanner pour lire la sortie ligne par ligne. Chaque ligne peut ensuite être enregistrée ou traitée selon les besoins. En gérant Stdout de cette manière, vous pouvez rediriger la sortie du processus vers votre journal pendant qu'il est encore en cours d'exécution, garantissant ainsi la journalisation en temps opportun des informations importantes pour votre service.

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!

Déclaration:
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