背景
1、app有类似微信拍摄小视频功能,时长上限8s,视频文件保存在第三方云存储,app直接上传,后端数据库只记录视频的存放地址。
2、最近一次功能迭代,增加了小视频下载功能,小视频有可能在别的社交渠道传播,因此设想给小视频结尾增加平台logo.
方案评审
方案一
服务端统一处理,针对拍摄的视频,从第三方云存储拉取至本地,利用ffmpeg处理水印,再重新上传至第三方云存储(我们平台接入的云存储服务方不能提供在视频结尾增加
水印logo的功能,因此由平台自己处理)
优点:
成功率有保障,基本上服务端ffmpeg增加水印的成功率要高,服务器配置相比手机端要好很多,处理过程更快
缺点:
高峰期产生大量的视频,若服务器投入有限,整个处理周期会被拉长,完成上传带logo的小视频存在一定的延迟。
方案二
客户端在下载视频时增加logo水印。
优点:
分而治之,个人用户级别的视频处理,性能开销均在用户端,不会对服务端造成影响。
缺点:
1、插件兼容性问题,比如安卓必须os在某个特定版本之上才行,ios也无法保障
2、插件过大,差不多十几兆,app文件增长太大
3、安卓机机型太多,部分定制机、山寨机性能参差不齐,部分使用第三方插件性能不理想。
选定方案,方案一
综合考虑后还是先选定了方案一,服务端处理
实现
ffmpeg运行环境搭建
//TODO
增加水印命令
//TODO
遇到的问题
//TODO
浙公网安备 33010602011771号