登录
首页 >  Golang >  Go问答

读者从不从“StdoutPipe”中读取内容

来源:stackoverflow

时间:2024-04-06 19:57:36 415浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《读者从不从“StdoutPipe”中读取内容》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我正在尝试从长时间运行的(阻塞/类 shell)命令中读取标准输出,最终目标是创建一个 go 可以与之交互的 sidecar 进程。

我有以下 mcve:

func main() {
    var err error
    // Build the long-running command
    args := []string{"-i0", "-o0", "-e0", "/usr/local/bin/ipython"}
    cmd := exec.Command("stdbuf", args...)

    // Keep the stdin file descriptor open
    // Spawned command should block waiting for input
    _, err = cmd.StdinPipe()
    if err != nil {
        panic(err)
    }

    // Setup pipe of `Reader` type
    var stdoutBuf []byte
    stdout, err := cmd.StdoutPipe()
    if err != nil {
        panic(err)
    }

    // Start the command
    if err = cmd.Start(); err != nil {
        panic(err)
    }

    go func() {
        for {
            // Asynchronously continue reading from stdout
            n, err := stdout.Read(stdoutBuf)
            fmt.Println(n)
            if err != nil {
                panic(err)
            }
            fmt.Println(stdoutBuf)
            time.Sleep(time.Millisecond * 2000)
        }
    }()

    // Block forever
    if err = cmd.Wait(); err != nil {
        panic(err)
    }
}

从语义上讲,这种方法似乎可行。我希望 stdout.read 会返回一些内容(ipython shell 前导码),但 n 始终为 0。

  1. 为什么此示例中的 reader.read 从未读取任何内容?
  2. 有点相关的问题:如果没有什么可读的,有没有办法阻止读取 stdoutpipe

我认为进程本身没有任何问题(这会导致无效的文件描述符读取),因为 start 不会 panic 并且看起来 cmd.wait 永远阻塞。


解决方案


因为您正在读入大小为 0 的缓冲区,这就是 var stdoutbuf []byte 创建的内容。相反,使用如下内容:

stdoutBuf := make([]byte, 4096)

您可能还想使用 bufio

stdout.read 已经阻塞,就像 io.Reader 的典型情况(尽管不是必需的):

今天关于《读者从不从“StdoutPipe”中读取内容》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>