Windows冷知识:最小化远程桌面与ffmpeg – WhiteNight's Site
最小化远程桌面会中断ffmpeg的录制
我觉得这个应该算冷知识吧。
前情提要
远程桌面连接至虚拟机,并通过ffmpeg录屏
这里可能不太好理解。
我在用PC A。有一台远程的虚拟机PC B正在执行某些任务。我现在想在PC B上面通过ffmpeg录屏来记录这个任务的执行过程。那么我肯定是通过远程桌面连接到PC B上面,然后在PC B上面执行ffmpeg。
ffmpeg -f gdigrab -i desktop output.mp4
最小化窗口后,ffmpeg终止录制
couldn’t get cursor info、does nost contain any stream
你都远程桌面了,那肯定是不想在录制的过程中还一直盯着PC B。正常来说,你肯定是最小化PC B的远程窗口,把它挂后台放那录制然后做其他的事情去。
问题来了,当你切换回去远程桌面的时候,你发现录制失败了。报的错都是些coutldn’t get cursor info,not contain any stream之类的错误。ffmpeg也没有输出output.mp4这个文件。
问题出在哪呢?
远程桌面的优化机制
最小化后进入无GUI模式
是的,Windows为了优化,在窗口最小化后窗口会进入无GUI模式。当你重新切换到这个窗口的时候又会让它进入到GUI模式。
这点平时不注意还是很难发现的,毕竟用户从体感上来说就是无缝切换。但还有个问题,这和ffmpeg有什么关系?我们用的是远程桌面,远程桌面关了并不会导致虚拟机关机,也不会关闭虚拟机的显示屏。不过远程连接的时候被连接的物理机会被弹回到登录界面,这点还是我偶然发现的。
解决方案
不点最小化,完事
一般来说平时也很难碰到ffmpeg+远程桌面的场景。如果真碰到了,不点最小化那个按钮就行。我试了几次,发现它的触发机制应该是点击“最小化”按钮之后就会把GUI停掉。
所以你不点它就行了。你可以把窗口拖的很小;也可以不全屏,通过点击窗口外面的部分来聚焦新的窗口,此时远程桌面只是在屏幕上显示的“层级”变了,它的GUI界面还是在正常跑着。
为什么ffmpeg录制会中断
两种想法
讲真这都是推测,我有两种思路。
写者注
俺寻思…..
- 我们的ffmpeg的源设置为desktop,即桌面。桌面这个最大的GUI界面都没了,那ffmpeg肯定找不到能捕获的源,所以才会中断录制。
但是这个思路不太对劲,就像我们上面说的那样,你改远程桌面的分辨率也好,关闭远程桌面也好,都不会影响到被连接主机的桌面。你通过远程连接在cmd输个指令跑个python,远程连接关闭之后python程序也会跟着停吗?很明显不会。
还有一种思路
- gdigrab是基于Win32的GDI,即图形显示接口的屏幕捕获设备。如果远程连接最小化,此时物理机处于登录界面,而远程桌面又进入的无GUI模式。那么此时GDI可能处于关闭状态——因为GDI找不到任何一个可用的GUI界面。导致gdigrab捕获着捕获着,发现接口关了,所以ffmpeg录制中断。
我个人觉得后者更合理些。不过我也没看源码,而且可能和RDP的实现原理有关。远程桌面到底是将啥推流给你的,这我也还没仔细看过。以后有时间可能再补充补充,这里就先过了。