Abh*_*rty 4 memory video command ffmpeg
可能是最陈词滥调的问题之一,但问题是:所以我有一个 Ubuntu 服务器作为一台独立的机器运行,仅用于处理 FFMPEG 作业。它有 4 个 vCPU、4GB RAM、80GB 存储。我目前正在使用此脚本将视频转换为 HLS 播放列表:https://gist.github.com/maitrungduc1410/9c640c61a7871390843af00ae1d8758e这适用于所有视频,包括从 iPhone 录制的 4K 视频。但是,我正在尝试添加水印,因此我更改了该脚本的第 106 行
从:
cmd+=" ${static_params} -vf scale=w=${widthParam}:h=${heightParam}"
Run Code Online (Sandbox Code Playgroud)
到:
cmd+=" ${static_params} -filter_complex [1]colorchannelmixer=aa=0.5,scale=iw*0.1:-1[wm];[0][wm]overlay=W-w-5:H-h-5[out];[out]scale=w=${widthParam}:h=${heightParam}[final] -map [final]"
Run Code Online (Sandbox Code Playgroud)
现在,这在 Youtube 或其他来源的视频中完美运行,但当我尝试使用 iPhone 上的 4K 视频时,RAM 使用量在不到一分钟的时间内从 250MB 增加到 3.8GB,并使整个过程崩溃。所以我寻找了一些类似的问题:
我知道 FFMPEG 需要大量内存消耗,但我不确定在不将流保留在内存中而是实时释放任何内存分配的情况下处理视频的确切方法是什么。即使我们决定在没有水印的情况下工作,它仍然需要大约 1.8GB RAM 来处理 5 秒的 4K 视频,这会产生一个风险,如果我们的用户上传更长的视频,最终会导致服务器崩溃。我考虑过ulimit,但这似乎确实限制了 FFMPEG,而不是编写改进的命令。让我知道如何解决这个问题。谢谢
Abh*_*rty 10
好吧,我找到了解决方案。问题是 4K 视频的比特率极高,它会加载到您的 RAM 上进行处理,这filter_complex最终会杀死您的进程。为了解决这个问题,我做的第一件事是将输入视频转码为 H264 格式(如果您愿意,您可以设置自定义比特率,但我忽略了这一点)。所以我在这个脚本的第58行之后添加了这个新命令https://gist.github.com/maitrungduc1410/9c640c61a7871390843af00ae1d8758e
ffmpeg -i SOURCE.MOV -c:a aac -ar 48000 -c:v libx264 -profile:v main -crf 19 -preset ultrafast /home/myusername/myfolder/out.mp4
Run Code Online (Sandbox Code Playgroud)
现在我们有了一个新处理的out.mp4. 我们将沿着脚本第 121 行删除它。这样做的原因是为了阻止 FFMPEG 一次性超载所有命令。现在我们将删除第 107 至 109 行并执行以下操作:
filters=[1]colorchannelmixer=aa=0.5,scale=iw*0.1:-1[wm];[0][wm]overlay=W-w-5:H-h-5[out];[out]scale=w=${widthParam}:h=${heightParam}[final]
cmd=""
cmd+=" ${static_params} -filter_complex ${filters} -map [final]"
cmd+=" -b:v ${bitrate} -maxrate ${maxrate%.*}k -bufsize ${bufsize%.*}k -b:a ${audiorate}"
cmd+=" -hls_segment_filename ${target}/${name}_%03d.ts ${target}/${name}.m3u8"
ffmpeg ${misc_params} -i /home/myusername/myfolder/out.mp4 -i mylogo.png ${cmd}
Run Code Online (Sandbox Code Playgroud)
所以现在我们在循环内运行 FFMPEG 来处理每个分辨率的基础输出。这将立即消除内存中所有过滤器的过载。根据您的用例,您甚至可能想要删除第 53 行。
测试
我最后的想法
我不是 FFMPEG 专家,但我认为这些信息会对可能有类似问题的人有所帮助。
| 归档时间: |
|
| 查看次数: |
5864 次 |
| 最近记录: |