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

简介: 直播转点播(直转点)是将直播流同步录制为点播视频,并支持媒资管理、媒体处理(转码及内容审核 / 智能首图等 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


相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
6月前
|
Web App开发 编解码 网络协议
视频直播技术干货(十一):超低延时视频直播技术的演进之路
本文将带您了解超低延时视频直播技术的优化和演进历程。
125 0
视频直播技术干货(十一):超低延时视频直播技术的演进之路
|
视频直播
视频直播源码技术知识分享:连麦功能(一)
我们开发视频直播平台就要去了解视频直播开发相关功能知识,这对我们开发平台有着重要的作用,连麦技术就是视频直播源码重要的技术功能之一,每一个功能技术都有自己的用武之地
视频直播源码技术知识分享:连麦功能(一)
|
存储 编解码 弹性计算
阿里云视频直播服务介绍|学习笔记
快速学习阿里云视频直播服务介绍
阿里云视频直播服务介绍|学习笔记
|
编解码 边缘计算 视频直播
视频直播服务实战|学习笔记
快速学习视频直播服务实战
视频直播服务实战|学习笔记
|
编解码 算法 开发工具
直播泛在化的今天, 如何快速搭建不同场景的直播系统
目前,不同的直播业务场景的直播需求越来越多,不同的直播需求对应着不同的技术侧重点。本篇演讲将通过介绍阿里云的直播技术架构,从客户的角度讲解如何集成阿里云的直播产品,描绘在阿里云视频云直播系统内进行快速的场景搭建效果,展示其直播系统的技术特点。
直播泛在化的今天, 如何快速搭建不同场景的直播系统
|
存储 缓存 NoSQL
开发视频直播系统,视频直播系统源码是核心技术
了解视频直播行业的朋友应该清楚,对于开发视频直播系统而言,视频直播系统源码是真正的核心技术
开发视频直播系统,视频直播系统源码是核心技术
|
视频直播
拥有视频直播源码之后就万事大吉了吗,大错特错!
从2016年直播行业逐渐的兴起,虽然爆发式的上升已经过去,但是整个行业仍然保持着稳步上升的发展趋势,所以关于视频直播源码的开发市场也是持续的火爆。很多小白可能以为手里有了直播源码就可以开工了,殊不知关于流媒体传输方面的知识也是需要有一个简单了解的。
拥有视频直播源码之后就万事大吉了吗,大错特错!
|
存储 消息中间件 安全
在线教育视频直播最佳实践
本实践介绍手机端通过云视频直播服务来推流和拉流实现视频直播业务,同时利用MQTT微消息、内容安全和表格存储来解决。
在线教育视频直播最佳实践
|
JSON 数据安全/隐私保护 数据格式
在线教育场景下的点播试看功能实现
在线教育场景下,使用阿里云视频点播服务实现视频试看功能。
1441 0
在线教育场景下的点播试看功能实现
|
视频直播 Windows Go
直播APP源码,视频直播技术篇 。
直播行业现在是越发的火热,人们对于视频直播的热情也是久盛不衰,云豹直播的技术人员在这里就教大家编写一个小小的视频直播片段。Windows Media Player 系列(不同面板样式) 综合型:id=MediaPlayer type=application/x-oleobject width=21...
3255 0