use*_*065 5 linux nonblocking fifo tee mplayer
我正在尝试开发一个程序来播放和录制一些 rtmp 流。该程序是用Qt开发的。
我正在使用 rtmpdump 和 mplayer。由于两者都在单独的进程中运行,因此我使用 fifo 将流从 rtmpdump 传递到 mplayer。我需要单独的进程,因为 mplayer 需要由用户控制。所以 mplayer 在从属模式下运行。
这对于播放流来说效果很好。
现在我想将流录制到另一个文件。我知道我可以使用 mplayer 来做到这一点。但使用单个 mplayer 是不可能的,因为它仅支持播放或录制。于是想到使用tee命令来分割流,使用2个mplayer进程,一个用于录制,一个用于播放。
现在溪流像这样流动
rtmpdump | tee fifo_for_playing fifo_for recording
Run Code Online (Sandbox Code Playgroud)
一个 mplayer 正在读取 fifo_for_playing,另一个 mplayer 正在读取 fifo_for_recording。
现在的问题是,由于 mplayer 应该记录,只有当用户按下记录按钮时才会启动,fifo_for_recording 将阻塞 tee,因为它没有打开。所以玩也不会开始。
有人可以提出解决方案或更好的方法来实现这一目标吗?我想做的是使用非阻塞 fifo 进行发球。因此,即使没有打开一个fifo进行读取,它也不会阻塞tee。
小智 1
Fifo 没有缓冲区(或者即使有缓冲区也非常小)。如果你写了它而没有人读你就会阻塞,正如你所发现的那样。
您可以编写一个小程序来读取 fifo 并将其缓冲到内存或磁盘中。也许 dd 程序可以做到这一点?
或者您可以在循环中使用 -stop 选项调用 rtmpdump,并将其输出写入文件。然后以不使用 fifo 的老式方式处理文件。