文件下载的问题

2020-11-25 09:34:21 +08:00
 zhaoxj58

迫生,老板分配了这样一个任务。

给前台提供 http 接口,提供 mp4 视频下载功能。 后台需要从对象存储服务中去获取多个 mp4 源文件片段,然后重新编码成一个完整 mp4 文件返回给前端。

现在的实现方式,先从对象服务中读取所需的源文件片段,然后编成 mp4,再临时存在本地磁盘,然后再读取全部到内存,再通过 http 接口返回给前台,然后删除磁盘文件。

问题是现在每次请求都有磁盘的读写,然后也是将整个编好的文件读到内存,最后再删除磁盘文件,感觉不是特别好。

哪位大哥有更好的方案吗,救救孩子

1375 次点击
所在节点    问与答
9 条回复
pabupa
2020-11-25 09:40:24 +08:00
302 到 oss 不就行了吗
jifengg
2020-11-25 10:12:41 +08:00
有碎片的话,建议要么提供 m3u8 给前端(参考爱奇艺),要么给列表给前端(参考腾讯视频)。这种实时合成的太耗 CPU 和 IO 了。
另外是流量,对象存储直接给到前端( 302 过去),流量不用走服务器,不然服务器的带宽是瓶颈。
前端没法改的话,只能存的时候合成大文件存了。
wangkun025
2020-11-25 10:17:30 +08:00
只能这样吧。
前端先提交任务,你这边合成好之后,让他们下载,下载完可以直接删除,也可以手工删除。
zhaoxj58
2020-11-25 10:47:41 +08:00
@jifengg 嗯,要求提供两种可选格式的,一种是 m3u8,一种是 mp4
zhaoxj58
2020-11-25 10:48:20 +08:00
@pabupa 直接 302 过去,没法做视频合成了
jifengg
2020-11-25 10:49:27 +08:00
@zhaoxj58 那就实际问题实际解决。总之,虽然实时合成是可以做到的,但实在是不推荐的。
VHacker1989
2020-11-25 12:00:13 +08:00
为什么要写回磁盘呢,直接返回不就行了。而且 http 协议本身支持 range,从 oss 取到后算好 range 直接返回前端就行了,合并都不用
nikandaoleshenme
2020-11-25 13:39:44 +08:00
初次下载完后,将生成的新文件上传到 OSS,下次碰到相同的请求重定向到 OSS 上去
kuro1
2020-11-25 14:30:36 +08:00
OSS 流量+服务器流量 费用成本有点高

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

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

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

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

© 2021 V2EX