产品百科 |直播转点播最佳实践

简介: 直播转点播(直转点)是将直播流同步录制为点播视频,并支持媒资管理、媒体处理(转码及内容审核 / 智能首图等 AI 处理)、内容制作(云剪辑)、CDN 分发加速等一系列操作,可配置工作流自动处理,也可通过 API/SDK 灵活触发。

直播转点播(直转点)是将直播流同步录制为点播视频,并支持媒资管理、媒体处理(转码及内容审核 / 智能首图等 AI 处理)、内容制作(云剪辑)、CDN 分发加速等一系列操作,可配置工作流自动处理,也可通过 API/SDK 灵活触发。

准备工作

上述准备工作完成后,即可开始进行接入。

说明 下文中仅存储、仅合成模板组需联系点播进行激活。

名词解释

直转点,结合视频点播的转码、云剪辑、AI 处理、事件通知等功能,可适应多种业务场景。

名词解释:

  • 录制转码模板组:直播录制到点播同时,点播会使用该模板组对视频进行转码操作。
  • 合成转码模板组:多个录制视频进行自动合成时,点播会使用该模板组对视频进行合成 + 转码操作。
  • 仅存储:对直播内容进行录制后,不进行任何后续操作。
  • 仅合成:对直播内容进行合成后,不进行任何后续操作。
  • 直播录制周期:直播录制到点播的周期,如一场直播 3 个小时,如果需要在直播过程中就可提供已录制内容的点播服务,则可设置录制周期为 1 小时,即直播 1 小时过后,点播可提供前一小时内容的点播观看服务。

实践 1

直播录制 + 自动转码 + CDN 加速

直播录制后快速将录制文件进行转码和 CDN 加速,供用户进行点播播放,适用于大部分直播场景 (不需要对内容进行二次加工)

流程如下:

image.png

  1. 客户进行直播推流
  2. 推流达到一个录制周期,则会自动将录制文件添加到点播系统。
  3. 点播记录完成后,会生成点播系统的唯一视频 ID,并将该视频信息回调给用户,即 AddLiveRecordVideoComplete 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  4. 点播系统检测用户录制配置中的录制转码组 ID (该转码组中含有具体码流转码任务),进行对应的转码操作。
  5. 截图完成、单个码流转码完成、全部码流转码完成时,会给用户进行回调 (回调顺序无时序),用户需根据回调信息中的 VideoId 进行视频状态更新。转码完成后,即可进行后续的播放操作 (转码回调信息中含播放地址或后续通过 GetPlayInfo 接口根据 VideoId 进行播放地址获取,该播放地址已经经过 CDN 加速)。

实践 2

直播录制 + 仅存储到点播 + 手动发起转码 + CDN 加速

部分用户希望将直播录制的视频仅先存储到点播,且先不进行后续的转码操作,则可在新建录制配置时,将录制转码组选择为仅存储模板组 (注:仅存储模板组需联系点播进行激活)。如果后续希望对视频进行转码,则可进行手动触发转码操作。同时,可配合点播云剪辑功能进行使用,效果更佳。

适用场景:直播完成后,需要对内容进行二次加工,如体育赛事、游戏直播剪辑等,后续由用户主动发起转码和 CDN 加速全流程 (转码完成后点播会自动对输出文件进行 CDN 加速)

流程如下:

image.png

  1. 客户进行直播推流。
  2. 推流达到一个录制周期,则会自动将录制文件添加到点播系统。
  3. 点播记录完成后,会生成点播系统的唯一视频 ID,并将该视频信息回调给用户,即 AddLiveRecordVideoComplete 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  4. 点播系统检测用户录制配置中的录制转码组 ID (此时为仅存储模板组),则点播系统不进行后续转码操作。
  5. 用户对该视频手动触发转码操作 (调用转码任务 API),在此之前可进行云剪辑等操作。
  6. 截图完成、单个码流转码完成、全部码流转码完成时,会给用户进行回调 (回调顺序无时序),用户需根据回调信息中的 VideoId 进行视频状态更新。转码完成后,即可进行后续的播放操作 (转码回调信息中含播放地址或后续通过 GetPlayInfo 接口根据 VideoId 进行播放地址获取,该播放地址已经经过 CDN 加速)。

实践 3

直播录制 + 多周期视频自动合并

部分用户希望将自己录制周期生成的多个文件 (如录制周期为 20 分钟,一次直播 1 个小时,则会生成三个视频) 进行视频合成,再将合成后的视频进行处理,点播提供了自动合成的功能。可在新建直播录制配置时,将自动合成开关打开,并且配置进行合成时所使用的合成转码模板组 (也可配置为仅合成,后续由用户触发转码,与前两节所述区别相同)。点播会在用户断流超过指定时间 (可由直播进行配置断流超时时间) 后,进行本次直播的视频自动合成并根据转码配置进行后续操作。

合成 + 自动转码

适用场景:一场直播完成后,需要对所有录制周期内的分段进行自动合并,同时发起转码等全流程。如体育赛事、教育多节授课合并等

流程如下:

image.png

  1. 客户进行直播推流。
  2. 推流达到一个录制周期,则会自动将录制文件添加到点播系统。
  3. 点播记录完成后,会生成点播系统的唯一视频 ID,并将该视频信息回调给用户,即 AddLiveRecordVideoComplete 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  4. 客户断流超时或主动触发断流。
  5. 点播收到直播发送的本次直播结束消息。
  6. 点播系统检测用户录制配置中的合成配置,判断是否需要发起自动合成。如果需要,则按照录制配置中的合成转码组进行合成和转码。
  7. 视频开始合成,点播会生成一个合成后视频的唯一视频 ID,并将该视频信息回调给用户,即 LiveRecordVideoComposeStart 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  8. 视频源文件合成完成后,点播会将该状态回调给用户,即 FileUploadComplete 通知。
  9. 截图完成、单个码流转码完成、全部码流转码完成时,会给用户进行回调 (回调顺序无时序),用户需根据回调信息中的 VideoId 进行视频状态更新。转码完成后,即可进行后续的播放操作 (转码回调信息中含播放地址或后续通过 GetPlayInfo 接口根据 VideoId 进行播放地址获取,该播放地址已经经过 CDN 加速)。

合成 + 手动发起转码

可在新建直播录制配置时,将自动合成开关打开,并且配置进行合成时所使用的合成转码模板组 (本情况配置成仅合成,后续由用户触发转码)。

适用场景:一场直播完成后,需要对所有录制周期内的分段进行自动合并,合并后文件不做任何处理,由用户进行二次加工,如云剪辑等,后续再进行手动转码,如视频内嵌广告、体育赛事空挡部分内容剪切等。

流程如下:

image.png

  1. 客户进行直播推流。
  2. 推流达到一个录制周期,则会自动将录制文件添加到点播系统。
  3. 点播记录完成后,会生成点播系统的唯一视频 ID,并将该视频信息回调给用户,即 AddLiveRecordVideoComplete 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  4. 客户断流超时或主动触发断流。
  5. 点播收到直播发送的本次直播结束消息。
  6. 点播系统检测用户录制配置中的合成配置,判断是否需要发起自动合成。如果需要,则按照录制配置中的合成转码组进行合成和转码,由于本场景配置的仅合成,则点播系统不会自动发起转码。
  7. 视频开始合成,点播会生成一个合成后视频的唯一视频 ID,并将该视频信息回调给用户,即 LiveRecordVideoComposeStart 通知,并附带直播相关的 DomainName、AppName、StreamName 信息。客户收到回调后,需记录该视频信息,并以该 VideoId 作为索引进行后续视频状态更新。
  8. 视频源文件合成完成后,点播会将该状态回调给用户,即 FileUploadComplete 通知。此时,代表本次录制合成的源文件已经处于正常就绪状态,用户可对该视频进行后续的转码触发等操作。
  9. 用户对该视频手动触发转码操作 (调用转码任务 API),在此之前可进行云剪辑等操作。
  10. 截图完成、单个码流转码完成、全部码流转码完成时,会给用户进行回调 (回调顺序无时序),用户需根据回调信息中的 VideoId 进行视频状态更新。转码完成后,即可进行后续的播放操作 (转码回调信息中含播放地址或后续通过 GetPlayInfo 接口根据 VideoId 进行播放地址获取,该播放地址已经经过 CDN 加速)。


「视频云技术」你最值得关注的音视频技术公众号,每周推送来自阿里云一线的实践技术文章,在这里与音视频领域一流工程师交流切磋。

image.png


相关文章
|
存储 NoSQL 数据库
数据模型
一、数据模型 数据模型是用于描述现实世界中各种实体、属性和实体之间关系的一种抽象表示方法。它是在计算机系统中对数据进行组织和管理的基础,用于定义数据的结构、约束和操作。 数据模型可以分为以下几种类型: 1. 层次模型:层次模型是一种树状结构的数据模型,其中数据以层次结构进行组织。每个节点可以有多个子节点,但只能有一个父节点。典型的层次模型是树形数据库。 2. 网状模型:网状模型是一种复杂的数据模型,其中数据之间可以有多对多的关系。网状模型使用指针来表示数据之间的关系,典型的网状模型是CODASYL数据库。 3. 关系模型:关系模型是一种基于关系代数的数据模型,其中数据以表的形式进行组织。关系模
969 0
|
3月前
|
Java 数据库连接 数据格式
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
本文系统梳理Java主流注解体系,涵盖Spring核心组件(@Component、@Service等)、依赖注入(@Autowired、@Resource)、Web开发(@RestController、@PathVariable)、配置启动(@SpringBootApplication、@Configuration)、MyBatis/Plus、事务AOP(@Transactional、@Aspect)及测试等八大类,辅以对比表格及思维导图。
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
|
运维 监控 网络协议
物联网设备状态监控全解析:从告警参数到静默管理的深度指南-优雅草卓伊凡
物联网设备状态监控全解析:从告警参数到静默管理的深度指南-优雅草卓伊凡
428 11
物联网设备状态监控全解析:从告警参数到静默管理的深度指南-优雅草卓伊凡
|
监控 测试技术
【亮剑】理解CPU负载对服务器稳定性的重要性,并提供了诊断和解决CPU负载过高问题的步骤
【4月更文挑战第30天】本文阐述了理解CPU负载对服务器稳定性的重要性,并提供了诊断和解决CPU负载过高问题的步骤:1) 使用监控工具分析CPU使用率和系统负载;2) 深入排查运行队列、进程占用、系统调用和硬件状态;3) 根据排查结果进行代码优化、调整进程优先级或限制CPU使用率,必要时升级硬件。建议建立监控体系,定期性能测试,并持续优化以保证服务器高效运行。
814 1
|
SQL 存储 监控
通过Logstash实现mysql数据定时增量同步到ES
通过Logstash实现mysql数据定时增量同步到ES
2162 0
通过Logstash实现mysql数据定时增量同步到ES
|
存储 缓存 算法
《智能指针频繁创建销毁:程序性能的“隐形杀手”》
智能指针是C++中管理内存的重要工具,自动处理内存分配与释放,有效防止内存泄漏等问题。然而,频繁创建和销毁智能指针会增加程序开销,导致内存碎片化、缓存效率下降及多线程环境下的锁竞争加剧,影响性能。合理规划对象生命周期和智能指针使用范围,优化内存布局,可有效缓解这些问题,提升程序效率。
341 3
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
安全 项目管理 开发工具
探索 GitHub:现代开发者的协作平台
GitHub 是一个基于 Git 的版本控制和协作平台,广泛应用于软件开发和项目管理。它不仅提供代码托管服务,还是开发者社区和开源项目的重要平台。本文介绍了 GitHub 的核心功能(如代码托管、协作工具、CI/CD 集成等)、使用技巧(如规范化提交信息、参与开源项目等),帮助开发者提升效率和协作能力。GitHub 自2008年成立以来,已成为全球最大的代码托管平台,支持团队协作和项目管理。
|
人工智能 云计算 Anolis
装机量破800万台!开源操作系统龙蜥全新发布官方正式版
第二届龙蜥操作系统大会在京举办。龙蜥社区作为国内领先的开源操作系统根社区,推出的Anolis OS及衍生版装机量已突破800万套,并在会上发布Anolis OS 23 官方正式版,全面兼容国内外主流CPU、GPU架构。并推出三大开源社区计划,推动开源操作系统实现商业化的良性循环发展。
516 4
|
存储 SQL 数据库