首頁 >後端開發 >Golang >如何從 Go 中執行的命令串流即時輸出?

如何從 Go 中執行的命令串流即時輸出?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-24 05:48:09753瀏覽

How to Stream Live Output from Executed Commands in Go?

執行指令的即時輸出

此程式碼片段展示了在Go 中執行指令並擷取其輸出時經常遇到的問題:輸出變為僅在命令執行完成後才可用。為了解決這個問題,提供了一個修改後的解決方案,允許即時串流命令的輸出。

cmdParams := [][]string{
    {filepath.Join(dir, path), "npm", "install"},
    {filepath.Join(pdir, n.path), "gulp"},
}

for _, cp := range cmdParams {
    log.Printf("Starting %s in folder %s...", cp[1:], cp[0])
    cmd := exec.Command(cp[1], cp[2:]...)
    cmd.Dir = cp[0]

    stdout, err := cmd.StdoutPipe()
    if err != nil {
        log.Printf("%s cmd.StdoutPipe() error: %v\n", cp[1:], err)
        return
    }
    // Start command:
    if err = cmd.Start(); err != nil {
        log.Printf("%s start error: %v\n", cp[1:], err)
        return
    }

    // Stream command output:
    scanner := bufio.NewScanner(stdout)
    scanner.Split(bufio.ScanRunes)
    for scanner.Scan() {
        fmt.Print(scanner.Text())
    }
    if scanner.Err() != nil {
        log.Printf("Reading %s stdout error: %v\n", cp[1:], err)
        return
    }

    // Get execution success or failure:
    if err = cmd.Wait(); err != nil {
        log.Printf("Error running %s: %v\n", cp[1:], err)
        return
    }
    log.Printf("Finished %s", cp[1:])
}

解釋:

  • cmd.StdoutPipe()建立一個管道,讓我們讀取指令的標準輸出即時。
  • bufio.NewScanner(stdout) 建立一個掃描儀,透過符文(字元)從輸出管道讀取。
  • scanner.Scan() 讀取並列印每個字元。可用。
  • 循環繼續讀取和列印字符,直到命令完成或發生錯誤。
  • 指令之後完成後,列印剩餘的輸出,並檢索指令的退出狀態。

附加說明:

  • 此解決方案僅串流標準輸出。標準錯誤也可以使用 Command.StderrPipe() 進行串流傳輸。
  • 某些指令可能不會將所有內容寫入其標準輸出或錯誤。在這種情況下,輸出可能無法正確串流。

以上是如何從 Go 中執行的命令串流即時輸出?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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