问题:
使用 exec.Command 执行进程时,如何您将其输出实时重定向到您的日志吗?
上下文:
等待进程完成然后记录其组合输出的传统方法并不适用适用于长时间运行或未完成的流程。实时写入标准输出对于不使用终端的服务也没有帮助。
解决方案:
实时捕获并记录进程输出,您可以利用管道:
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) }
这种方法允许您使用 goroutine 捕获 stdout 和 stderr。
以上是如何在 Golang 中将 Exec 命令输出实时重定向到您的日志?的详细内容。更多信息请关注PHP中文网其他相关文章!