从命名管道读取不会给出任何输出并无限期地阻塞代码
Reading from a named pipe won't give any output and blocks the code indefinitely
我写了一段代码,目的是IPC。预期的行为是代码从命名管道读取内容并打印字符串(使用 Send("log", buff.String())
)。首先,我在 goroutine 中打开命名管道 'reader',当 reader 打开时,我发送一个信号,表明数据可以写入命名管道(使用 Send("datarequest", "")
)。这是代码:
var wg sync.WaitGroup
wg.Add(1)
go func() {
//reader part
file, err := os.OpenFile("tmp/"+os.Args[1], os.O_RDONLY, os.ModeNamedPipe)
if err != nil {
Send("error", err.Error())
}
var buff bytes.Buffer
_, err = io.Copy(&buff, file)
Send("log", buff.String())
if err != nil {
Send("error", err.Error())
}
wg.Done()
}()
Send("datarequest", "")
wg.Wait()
下面是发送信号时执行的代码:
//writer part
file, err := os.OpenFile("tmp/" + execID, os.O_WRONLY, 0777)
if err != nil {
c <- "[error] error opening file: " + err.Error()
}
bytedata, _ := json.Marshal(moduleParameters)
file.Write(bytedata)
所以我得到的行为是,当我尝试复制代码时,代码会无限期地阻塞。我真的不知道为什么会这样。当我在终端中使用 cat 对其进行测试时,我确实得到了预期的结果,所以我的问题是如何使用代码获得相同的结果?
编辑
execID 与 os.Args[1]
相同
作者应在使用 file.Close()
完成发送后关闭文件。请注意 file.Close()
可能 return 错误。
我写了一段代码,目的是IPC。预期的行为是代码从命名管道读取内容并打印字符串(使用 Send("log", buff.String())
)。首先,我在 goroutine 中打开命名管道 'reader',当 reader 打开时,我发送一个信号,表明数据可以写入命名管道(使用 Send("datarequest", "")
)。这是代码:
var wg sync.WaitGroup
wg.Add(1)
go func() {
//reader part
file, err := os.OpenFile("tmp/"+os.Args[1], os.O_RDONLY, os.ModeNamedPipe)
if err != nil {
Send("error", err.Error())
}
var buff bytes.Buffer
_, err = io.Copy(&buff, file)
Send("log", buff.String())
if err != nil {
Send("error", err.Error())
}
wg.Done()
}()
Send("datarequest", "")
wg.Wait()
下面是发送信号时执行的代码:
//writer part
file, err := os.OpenFile("tmp/" + execID, os.O_WRONLY, 0777)
if err != nil {
c <- "[error] error opening file: " + err.Error()
}
bytedata, _ := json.Marshal(moduleParameters)
file.Write(bytedata)
所以我得到的行为是,当我尝试复制代码时,代码会无限期地阻塞。我真的不知道为什么会这样。当我在终端中使用 cat 对其进行测试时,我确实得到了预期的结果,所以我的问题是如何使用代码获得相同的结果?
编辑
execID 与 os.Args[1]
相同作者应在使用 file.Close()
完成发送后关闭文件。请注意 file.Close()
可能 return 错误。