指令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() 會阻塞,直到指令完成,確保維持輸出順序。
此解決方案滿足所有要求:
以上是如何同時將命令輸出記錄並列印到控制台?的詳細內容。更多資訊請關注PHP中文網其他相關文章!