前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >扩展不同视频播放中的读取操作

扩展不同视频播放中的读取操作

作者头像
用户1324186
发布2020-12-24 11:16:06
7960
发布2020-12-24 11:16:06
举报
文章被收录于专栏:媒矿工厂媒矿工厂

本次演讲来自Video @Scale 2020,演讲者是来自Facebook的软件工程师David Zhang。本次演讲主要介绍了Facebook如何将不同播放场景中的视频I\O操作方法进行结合,并提高I\O操作的效率和灵活性的方法。

David首先介绍了视频从拍摄到分发给用户的过程,并介绍了点播场景以及直播场景下对设备基础设施的要求进行了对比,并指出点播场景中利用数据块来存储视频,而直播场景中则是使用缓存。两种场景下的存储方式和API接口并不能兼容。

随后David表示这两种场景下的存储方式可以进行合并。但是,David指出这其中存在的挑战。首先是两种方式的API并不相同。数据块存储中是一次读入需要的数据,而缓存中则是随着时间不断的加载新的数据;其次是没有办法根据播放场景的需要,来调节存储方式在可靠性和实时性的折衷。最后是现有的视频I/O操作方式中也很难进行扩展,当需要一个新的读写和存储方式时,很难与已有的方式进行结合。

接着David开始介绍他们在解决这一问题时所使用的方法“OIL”。OIL能够对不同的播放场景进行抽象化,并能作为一种操作I\O的语言。其中的API和一般的文件读写API非常相似。并且通过对不同的存储模块进行综合,使得在I\O读写时可以按需选择。不同存储方式的配置则是通过一个json文件来实现。通过将不同的存储方式表示为有向无环图中的一个节点,配置文件按照顺序读取图中的节点来更新配置。这样就可以通过调整图中的节点来实现在可靠性和实时性中的折衷。

David最后介绍了将缓存和数据块存储方式通过OIL结合起来的例子。通过将多个缓存存储模块并行的和数据块存储模块连接在配置文件的有向无环图中,就可以很好地实现利用空闲的存储区,提高I\O操作的效率,在直播场景中既能保证低延时又可以实现回放的功能。

附上演讲视频:

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-12-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 媒矿工厂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档