我正在寻找一个子程序,其中一个文件描述符被打开到给定的管道,这样open()调用就不会挂起,等待管道的另一端接收连接。

演示:

$ mkfifo /tmp/foobar.pipe
$ some_program --command-fd=5 5</tmp/foobar.pipe

在这种情况下,some_program在某些进程/tmp/foobar.pipe打开以进行写入之前不会运行;但是,即使没有接收到命令,O_NONBLOCK也会产生有用的效果,因此<=>需要立即执行

通过执行备用脚本语言(python,perl等)或使用<=>标志打开<=>的C包装器来执行此操作的机制是显而易见的;我正在寻找一种纯粹的bash解决方案,如果有可能的话。

有帮助吗?

解决方案

在设置管道时打开FD读/写而不是只读会阻止阻塞。

更具体一点:

$ mkfifo /tmp/foobar.pipe
$ some_program --command-fd=5 5<>/tmp/foobar.pipe

防止出现意外的阻塞行为,因为5<>/tmp/foobar.pipe在RW模式下打开(而不是像5</tmp/foobar.pipe那样以只读模式打开),尽管仍然设置了O_NONBLOCK。感谢waldner on irc://irc.freenode.org/#bash这个指针。

其他提示

我知道得到这种结果的唯一方法是黑客攻击:

mkfifo /tmp/foobar.in
mkfifo /tmp/foobar.out
( cat </tmp/foobar.in ) >/tmp/foobar.out &
some_program --command-fd=5 5</tmp/foobar.out

也许这会有所帮助: - )

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top