技术赋能-混流编排功能,助力京东618直播重保 | 京东云技术团队
每每到618、双11这样的大型活动的时候,每天都有几个重要的大v或者品牌直播需要保障。
以往的重点场次监播方式是这么造的:
对每路直播的源流、各档转码流分别起一个ffplay播放窗口,再手动调整尺寸在显示器桌面进行布局,排到一屏里来监播。
这样做的缺点:
-
操作复杂,手动调整画面不美观
-
不同的拉流时间点,起播时间有误差,画面无法协调一致
-
当拉多路流的时候,带宽也受限制,基本上拉3-4个2m码率以上的流本机就会卡顿了,此时如果流有问题,就不能准确判断卡顿来源了,检查起来也比较费劲
展示方式是这样的:
ffplay 'rtmp://stream1' & ffplay 'rtmp://stream2' & ffplay 'rtmp://stream3' & ffplay 'rtmp:/stream4' & ffplay 'rtmp://stream5' & ffplay 'rtmp://stream6' & ffplay 'rtmp://stream7' & ffplay 'rtmp://stream8'
PS:这么多的窗口,点着是挺麻烦的😓
在我们混流生产层能力完备后,就开始琢磨怎么将它赋能在平常或者大促的直播间重保上,同时也为了更加专业、更高效的进行监播,经过了一段时间的打磨,提炼了一个简单的混流编排功能。
它的工作模式是这样的:
在这里你可以创建混流任务,并支持你在不断流的状态下做到更新任务输入信息。
将要监播的直播流地址,需要展示的文字内容、布局方式、混流输出的模板配置进行下发,就可以拉到自动编排好的直播流地址。
它现在长这个样子:
最终呈现出来的混流的效果是这样的😁:
也可以是这样的:
也可以呈现其他的布局方式,目前还没做的那么丰富,不过底层能力和api接口是都支持的,完全灵活布局。
在混流任务运行过程中,可以自由修改混流输入源的配置。
这种新型的监播方式,可以直观的区分源流、各档转码流的播放效果:画面内容是否正常,有无花屏、是否卡顿?
当出现问题时能够指导我们快速做出决策:
-
转码流有问题,源没有问题,快速排查任务日志,定位是什么原因导致
-
转码流有问题,源也有问题,迅速问题源流的流详细信息,定位问题并通知业务方进行操作
-
主流都有问题,备流没问题,通知业务方迅速切备流
还有其他的一些有点:
-
操作简单方便,还可以记忆配置,下次直接修改
-
每个播放端只需拉一路流,节省本地带宽
-
最多可以支持16路混流,一屏监播16路流的画面
-
不断流,轻松切换各种布局
-
不断流,随便操作流的添加、删除、修改
-
方便分享给其他人进行播放
混流布局功能的底层实现框架:
- 定义通用的layout布局结构-BasicClip
{ ClipType string `json:"clipType"` LeftMargin int `json:"leftMargin"` PosX *int `json:"posX"` PosY *int `json:"posY"` Width int `json:"width"` Height int `json:"height"` }
在此基础上扩展出更丰富的BorderClip, TextClip, ImageClip等类型,来满足不同的布局元素设计。
- 定义通用的videoMask结构,它可以包含多个clip interface, 即各种clip元素,在videoMask中各个clip是同一个layer的,只允许在限定的尺寸中进行布局。
type VideoMask struct { Layer int `json:"layer"` Clips []interface{} `json:"clips"` }
- 每个输入的视频流,可以包含多个videoMask,多个videoMask在最终overlay的时候,按定义的layer先后顺序进行铺叠,以达到最终的预期视频布局效果。
应用场景拓展
- 什么情况下使用混流?
◦当设备不支持同时拉多路流时使用混流,比如sip入会的场景。
◦需要多个视频画面、多个音频流合成一个直播流时使用混流,比如会议录制(rtc协议)场景、教育类场景(直播老师和学生的画面)、直播连麦的场景等。
总结:此次能在618重保期间发挥它的价值,也算是有所得。希望以后可以在日常直播、展会等其他重要直播活动中发挥作用。关于混流的产品介绍以及更多的使用场景也会在后续的文章中一一展开,敬请期待。
作者:京东科技 孟晓伟
来源:京东云开发者社区

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
【建议收藏】OceanBase 4.1 全面测评及部署流程,看这篇就够了
作者:杨家鑫 多点⾼级 DBA ,擅⻓故障分析与性能优化,喜欢探索新技术,爱好摄影。 背景 测试 OceanBase 对比 MySQL,TiDB 的性能表现,数据存储压缩,探索多点内部项目一个数据库场景落地 Oceanbase(MySQL->OceanBase)。 单机测试 准备 OBD 方式部署单机 文件准备 wget https://obbusiness-private.oss-cn-shanghai.aliyuncs.com/download-center/opensource/oceanbase-all-in-one/7/x86_64/oceanbase-all-in-one-4.1.0.0-100120230323143519.el7.x86_64.tar.gz?Expires=1681878350&OSSAccessKeyId=LTAI5tGVLeRRycCRGerZJMNC&Signature=4E8%2FW77U1MAqq1ttNvuljadkTq0%3D mv oceanbase-all-in-one-4.1.0.0-10012023032314...
- 下一篇
【Clickhouse】ReplaceingMergeTree引擎final实现合并去重探索 | 京东云技术团队
前言 在OLAP实践中,在有数据更新的场景中,比如存储订单数据,我们经常会用到ReplaceingMergeTree引擎来去重数据,以获取数据的最新状态。但是ReplaceingMergeTree引擎实现数据的去重合并的操作是异步的,这样在实际查询的时候,其实是仍然有一部分数据是未进行合并的。为了保证统计数据的准确性,比如订单金额,一个常用的方法是在查询时增加final关键字。那final关键字是如何合并数据的,以及合并的数据范围是怎样的,本文就对此做一个简单的探索。 知识准备 分片:分片就是clickhouse的实例节点,不同的分片就代表不同的节点或机器,分片之间是物理隔离的 分区:分区是一个表中通过指定的规则划分而成的逻辑数据集,比如日期分区,分区是一种逻辑上的,不同的分片上会有相同的分区 探索过程 探索过程比较长,请大家保持耐心,如果不想看过程,可以直接看结论哈,马上开始~ 本文基于的clickhouse版本为version 23.3.1.2823 创建表 创建ReplacingMergeTree引擎的表,分布式表union_order_onl_all_test,本地表union...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- MySQL8.0.19开启GTID主从同步CentOS8
- Mario游戏-低调大师作品
- Linux系统CentOS6、CentOS7手动修改IP地址
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Docker快速安装Oracle11G,搭建oracle11g学习环境