我正在尝试开发一个程序来播放和录制一些 rtmp 流。该程序是用 Qt 开发的。

我正在使用 rtmpdump 和 mplayer。由于两者都在单独的进程中运行,因此我使用 fifo 将流从 rtmpdump 传递到 mplayer。我需要单独的过程,因为 mplayer 需要由用户控制。所以 mplayer 以从属模式运行。

这对于播放流来说效果很好。

现在我想将流记录到另一个文件中。我知道我可以使用 mplayer 来做到这一点。但是使用单个 mplayer 是不可能的,因为它只支持播放或录制。所以想到使用tee命令来分割流并使用2个mplayer进程,一个用于录制,一个用于播放。

现在小溪像这样流动

rtmpdump | tee fifo_for_playing fifo_for recording

一个 mplayer 正在读取 fifo_for_playing,另一个正在读取 fifo_for_recording。

现在的问题是,由于应该记录的 mplayer 仅在用户按下记录按钮时才会启动,fifo_for_recording 将阻止 tee,因为它没有打开。所以玩也不会开始。

任何人都可以提出解决方案或更好的方法来实现这一目标吗?我想要做的是带有非阻塞 fifo 的 T 恤。所以即使一个fifo没有打开读取,它也不会阻塞tee..

最佳答案

Fifos 没有缓冲区(或者如果有缓冲区,则它非常小)。如果你给它写信而没有人在读你就会阻止,正如你发现的那样。

您可以编写一个小程序来读取 fifo 并将其缓冲在内存或磁盘中。也许 dd 程序可以做到这一点?

或者您可以在循环中使用带有 -stop 选项的 rtmpdump 调用,并将其输出写入文件。然后以没有先进先出的老式方式处理文件。

关于具有多个 fifo 的 Linux tee 命令。先进先出块三通,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/15874248/

10-12 02:16