首页  >  文章  >  后端开发  >  如何在 Go 中将命令输出同时重定向到控制台和日志文件?

如何在 Go 中将命令输出同时重定向到控制台和日志文件?

Susan Sarandon
Susan Sarandon原创
2024-11-03 22:07:30985浏览

How to Redirect Command Output to Console and Log File Simultaneously in Go?

同时将命令输出重定向到控制台和日志文件

将命令的 stdout 和 stderr 重定向到控制台和日志文件实时地,你可以使用 Go 中的 io.MultiWriter 类型。具体方法如下:

在提供的代码片段中,代码仅重定向到控制台,因为 cmd 的 Stdout 和 Stderr 字段分别设置为 os.Stdout 和 os.Stderr。要重定向到控制台和日志文件,请修改代码如下:

<code class="go">package main

import (
    "io"
    "log"
    "os"
    "os/exec"
)

func main() {
    // Logging capability
    f, err := os.OpenFile("log.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
    if err != nil {
        log.Fatalf("Error opening file: %v", err)
    }
    defer f.Close()
    mwriter := io.MultiWriter(f, os.Stdout)

    cmd := exec.Command("php", "randomcommand.php")
    cmd.Stdout = mwriter
    cmd.Stderr = mwriter

    if err := cmd.Run(); err != nil {
        log.Fatal(err)
    }
}</code>

mwriter 变量是 io.MultiWriter 的实例,其中包含日志文件和标准输出。通过将命令的 Stdout 和 Stderr 设置为此 mwriter,命令的输出会同时写入两个位置。

randomcommand.php 脚本可以保持不变,交替写入 stdout 和 stderr 20 次。当你运行 Go 程序时,输出将实时打印到控制台,并记录到指定的日志文件,保持写入 stdout 和 stderr 的准确顺序。

以上是如何在 Go 中将命令输出同时重定向到控制台和日志文件?的详细内容。更多信息请关注PHP中文网其他相关文章!

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