在使用 OBS 录制视频时,不少用户遇到过这样的问题:采用软件编码器 libx264 时,录制的文件尾部会出现少帧现象,而切换到硬件编码器(例如 h264_nvenc)后,这个问题明显减少甚至消失。本文将深入探讨这一现象的原因,并提供相应的解决方案。
1. OBS 的编码与录制架构
在 OBS(Open Broadcaster Software)中,视频录制通常涉及两个主要模块:
-
采集模块
负责捕获屏幕、摄像头或其他视频源的原始帧数据,这部分工作是异步进行的,且一般不会因为录制停止而立即停止。 -
输出模块
负责对捕获到的帧数据进行编码(视频和音频)、封装并写入文件。调用obs_output_stop(output);
后,输出模块会停止编码和写入操作,同时尽可能地刷新缓冲区内的数据。
在录制过程中,OBS 内部存在一个帧缓冲队列,存储着等待编码的帧数据。当录制结束时,OBS 会尝试将队列中尚未编码的帧数据尽量写入文件。不过,由于各模块异步工作的特点以及系统负载等因素,这个缓冲区可能并不能完全清空。例如日志中出现的提示:
d