首頁 >後端開發 >Golang >如何同時將命令輸出記錄並列印到控制台?

如何同時將命令輸出記錄並列印到控制台?

Patricia Arquette
Patricia Arquette原創
2024-11-04 01:12:02564瀏覽

How to Simultaneously Log and Print Command Output to Console?

指令Stdout 和Stderr 的同時控制台和日誌輸出

所提供程式碼的目標是將指令stdout 和stderr 印到控制台即時地同時按控制台順序將它們記錄到文件中,而無需修改命令本身。

為了實現這一點,我們可以利用 io.MultiWriter 型式。具體方法如下:

<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()

    // Define a MultiWriter that includes both the log file and stdout
    multiWriter := io.MultiWriter(f, os.Stdout)

    // Set stdout and stderr of the command to the MultiWriter
    cmd := exec.Command("php", "randomcommand.php")
    cmd.Stdout = multiWriter
    cmd.Stderr = multiWriter

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

透過將 multiWriter 定義為日誌檔案和 stdout 的組合,我們可以有效地將命令輸出同時寫入兩個目標。 cmd.Run() 會阻塞,直到指令完成,確保維持輸出順序。

此解決方案滿足所有要求:

  • 將 stdout 和 stderr 即時列印到控制台。
  • 將 stdout 和 stderr 記錄到文件,鏡像控制台輸出。
  • 遵守寫入 stdout 和 stderr 的確切順序。
  • 不修改指令本身。

以上是如何同時將命令輸出記錄並列印到控制台?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn