使用 nodejs 调用和在 macos 终端里直接调用 ffmpeg 转 m3u8,两者花费时间相差巨大

239 天前
 nathanleeinph

对于同一个 m3u8 及其 ts 资源,体积为 2.8g 左右,文件数 2760 个

使用 macOS 自带终端运行:ffmpeg -i ./index.m3u8 -c copy test.mp4 和在 nodejs 里使用“fluent-ffmpeg”这个库(依然是使用‘/opt/homebrew/Cellar/ffmpeg/6.0/bin/ffmpeg’)处理

终端处理仅仅需要 30 秒不到

而 nodejs 运行则需要 21 分钟

我是 nodejs 小白,执行命令的方式是在 vscode 这个编辑器里的终端执行 node ./foo.js

有人了解这个巨大差异产生的原因吗?

我推测是不是 vscode 或者 nodejs 只使用了单线程的关系??

965 次点击
所在节点    FFmpeg
5 条回复
zcf0508
239 天前
nodejs 使用的应该是 wasm 版本的 ffmpeg ,不是原生的
xiangyuecn
239 天前
终端命令有问题,2.8g 的视频,30 秒转码成 mp4 想想都不可能,估计只是用 mp4 容器简单封装了一下 ts 数据

21 分钟时间上倒是合理,进行了 mp4 转码
renmu
239 天前
你的问题,把 start 回调里的命令放出来
nathanleeinph
239 天前
@zcf0508

https://www.npmjs.com/package/fluent-ffmpeg
我最初也是担心是不是原生 ffmpeg ,但是查阅了 npm 上的文档,
fluent-ffmpeg 是可以指定 ffmpeg 的路径的,
并且默认是就是调用操作系统环境变量里的 ffmpeg ,我对比了使用 nodejs 版的 ffmpeg( https://www.npmjs.com/package/ffmpeg-static)和操作系统里的 ffmpeg 得到的结果一致

所以结论是,ffmpeg 是否原生与时间差异无关
nathanleeinph
239 天前
@xiangyuecn
@renmu

感谢两位的指出,确实是我的问题。。。。

nodejs 版多了一个 format('mp4')

在电脑前坐太久确实头昏脑胀犯低级错误,浪费大家时间了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/974227

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX