首页 >后端开发 >Golang >如何在 Golang 中将 Exec 命令输出实时重定向到您的日志?

如何在 Golang 中将 Exec 命令输出实时重定向到您的日志?

Patricia Arquette
Patricia Arquette原创
2024-11-17 12:38:01533浏览

How to Redirect Exec Command Output to Your Log in Real Time in Golang?

Golang:将 Exec 输出复制到日志

问题:

使用 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn