需求
有时我们会在程序中通过fork/execl方式调用ffmpeg进程执行某些命令,这通常比调用API更简单。然后我们等待这些命令执行完毕后ffmpeg进程自动就会结束,但如果我们的任务是需要长时间运行比如拉取rtsp流保存为mp4,我们希望这个工作可以随时终止,终止的时候ffmpeg要优雅的退出,即ffmpeg要可以在退出时执行写入mp4的元数据、正常关闭文件等清理工作,使他看起来就像是正常退出一样,ffmpeg可以吗?
实现
ffmpeg是可以的。
一旦我们以额外进程的方式运行ffmpeg,那么通知ffmpeg进程最简单的方式就是发送信号,ffmpeg进程优雅退出的也是这么实现的,即监听某些信号,在信号回调函数中终止正在进行的操作,进行优雅退出。我们知道ffmpg这个可执行程序对应的代码是由ffmpeg.c,下面我们就跟踪下代码看起其具体实现。
在ffmpeg.c的main函数中会调用ffmpeg_parse_options函数,ffmpeg_parse_options中会调用SIGNAL函数对SIGINT和SIGTERM这两个信号进行注册,回调函数为sigterm_handler
由下面sigterm_handler的实现可知,当这两个信号触发时,会将信号值赋值给received_sigterm,然后进行计算,如果接收的信号次数大于3则直接调用exit()进行强制退出了,而ffmpeg就是通过对received_sigterm的判断实现的优雅退出。