問題:
exec.Command を使用してプロセスを実行する場合、どのようにすればよいですかその出力をログインにリダイレクトしますreal-time?
コンテキスト:
プロセスが完了するのを待ってからその結合された出力をログに記録する従来のアプローチは、長時間実行されているプロセスや未完了のプロセスには適していません。 。リアルタイムでの stdout への書き込みも、ターミナルを使用しないサービスには役に立ちません。
解決策:
プロセス出力をリアルタイムでキャプチャしてログに記録するには、パイプを利用できます:
stdout, err := cmd.StdoutPipe() if err != nil { return 0, err } // Start the command after setting up the pipe if err := cmd.Start(); err != nil { return 0, err } // Read the command's stdout line by line in := bufio.NewScanner(stdout) for in.Scan() { log.Printf(in.Text()) // Log each line } if err := in.Err(); err != nil { log.Printf("error: %s", err) }
このアプローチでは、ゴルーチン。
以上がGolang で実行コマンドの出力をリアルタイムでログインにリダイレクトする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。