首页  >  文章  >  后端开发  >  如何将命令输出同时写入控制台和日志文件?

如何将命令输出同时写入控制台和日志文件?

Patricia Arquette
Patricia Arquette原创
2024-11-04 05:19:29980浏览

How Do I Simultaneously Write Command Output to Console and Log File?

同时将命令输出写入控制台和日志文件

您希望将命令的输出重定向到控制台和日志文件。现有代码将输出发送到控制台,但不记录它。要重定向两个流,请使用下面描述的技术。

要实现您的目标,请考虑以下方法:

将 Stdout 和 Stderr 重定向到 MultiWriter

创建一个结合文件和标准输出的MultiWriter。然后,在运行命令之前,将此 MultiWriter 分配给命令的 Stdout 和 Stderr 流。

示例代码

<code class="go">package main

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

func main() {
    // Open the log file for writing
    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()

    // Create a MultiWriter that combines the log file and standard output
    mwriter := io.MultiWriter(f, os.Stdout)

    // Construct the command
    cmd := exec.Command("ls")

    // Redirect Stdout and Stderr to the MultiWriter
    cmd.Stdout = mwriter
    cmd.Stderr = mwriter

    // Run the command
    err = cmd.Run()
    if err != nil {
        panic(err)
    }
}</code>

此代码打开一个日志文件,创建一个MultiWriter,将命令的流设置为 MultiWriter,并运行命令。输出将按正确的顺序实时重定向到控制台和日志文件。

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

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