DASH打包是指将多字幕、多音轨、多码率视频流生成一个Master Playlist文件的过程。在实际应用中,客户端可以根据自身网络情况动态选择并请求最合适的片段进行播放,能够显著改善带宽波动较大时的视频播放质量。本文介绍了新建DASH打包工作流、调用AddMedia接口指定视频及DASH打包工作流ID进行视频处理的操作步骤。
使用说明
DASH打包工作流目前只能通过API生成,不能通过控制台生成。通过API生成的工作流可以通过控制台查看和使用。更多信息,请参见新增媒体工作流。
操作步骤
在创建工作流时,请关注以下对象。创建工作流API接口,请参见新增媒体工作流。
说明多次打包只需设置一次工作流。
对象
描述
Topology
拓扑结构是指可自定义的业务处理流程,DAG。
Activity
活动是指组成拓扑结构的处理节点,在新建DASH打包工作流时要注意的活动请参见下文活动说明表。
Dependencies
依赖关系是拓扑结构中的边,指明活动之间的依赖。
表 1. 活动说明表 活动
描述
前后依赖
指定DASH打包配置,设置Master Playlist文件输出位置。
前置节点允许:Start。
后置节点允许:SubtitleGroup、AudioGroup、VideoGroup。
指定字幕分组ID和语言。
前置节点允许:PackageConfig。
后置节点允许:Transcode(仅字幕)。
指定音频分组ID和语言。
前置节点允许:PackageConfig。
后置节点允许:Transcode (仅音频)。
指定视频分组ID。
前置节点允许:PackageConfig。
后置节点允许:Transcode (仅视频)。
用于提取视频流、音频流、字幕流。
前置节点允许:SubtitleGroup、AudioGroup、VideoGroup。
后置节点允许:GenerateMasterPlayList。
打包生成活动。
前置节点允许:Transcode。
后置节点允许:Report。
调用新增媒体接口,需要注意以下几点:
指定媒体工作流ID。
若存在字幕提取,可以设置参数OverrideParams,以覆盖字幕Transcode活动中的固定字幕文件地址参数,如
{"subtitleTransNode":{"InputConfig":{"Format":"stl","InputFile":{"URL":"http://example-bucket-****.oss-cn-hangzhou.aliyuncs.com/package/subtitle/CENG.stl"}}}}
其中sutitleTransNode为工作流定义中的字幕抽取结点。工作流触发模式设置为:NotInAuto。
场景
源文件mxf格式(也可是其它格式如mp4、flv、m3u8(ts)),从源文件中提取3路音轨,提取2路视频流。提取2路WebVTT字幕,最终组合打包成一个Master Playlist:
设置DASH打包输出Master Playlist的位置及名称。
设置Bucket。
设置Location。
设置Master Playlist的名称。
活动定义如下:
{ "Parameters" : { "Output" : "{\"Bucket\": \"exampleBucket****\",\"Location\": \"oss-cn-hangzhou\",\"MasterPlayListName\": \"{MediaId}/{RunId}/dash/master.mpd\"}" }, "Type" : "PackageConfig" }
Output设置Master Playlist的存储位置及名称,参见PackageConfig活动支持的参数。
Type指定活动类型为PackageConfig。
活动定义:
"audio-cn-group" : {
"Name" : "audio-cn-group",
"Parameters" : {
"AdaptationSet" : "{\"Lang\":\"chinese\",\"Group\":\"AudioGroupChinese\"}"
},
"Type" : "AudioGroup"
}
Group:指定音频分组ID为AudioGroupChinese。
Type:类型为AudioGroup活动。
提取音轨。
从mxf源文件中提取音频流,需要去掉视频流。
输出的音频流参数。
活动定义:
"audioCNTransNode" : { "Name" : "audioCNTransNode", "Parameters" : { "Outputs" : "[{\"TemplateId\":\"d053297fc44f9DashTempla****\",\"AudioStreamMap\":\"0:a:0\",\"Video\":{\"Remove\":\"true\"}}]", "Representation" : "{\"Id\":\"chinese128k\",\"URI\":\"audiocn/cn-abc.mpd\"}" }, "Type" : "Transcode" }
视频分组。
"video-group" : {
"Name" : "video-group",
"Parameters" : {
"AdaptationSet" : "{\"Group\":\"VideoGroup\"}"
},
"Type" : "VideoGroup"
}
提取视频。
从mxf源文件中提取视频流,需要去掉音频流。
活动定义:
"videoTransSD" : { "Name" : "videoTransSD", "Parameters" : { "Outputs" : "[{\"TemplateId\":\"d861b90f6c0aed8f81095e5c5b85****\",\"Audio\":{\"Remove\":\"true\"}}]", "Representation" : "{\"Id\":\"476pSD\",\"URI\":\"videoSD/****.mpd\"}" }, "Type" : "Transcode" }
自定义转码模板ID:d861b90f6c0aed8f81095e5c5b857cba,可调用接口进行创建,容器格式为mpd。
在输出中移除掉音频流,请参见参数详情。
URI: 视频流提取后的名称及存储地址。
Type设置为Transcode,即转码活动。
字幕分组。
设置字幕分组ID。
活动定义:
"subtitle-cn-group" : { "Name" : "subtitle-cn-group", "Parameters" : { "AdaptationSet" : "{\"Lang\":\"Chinese\", \"Group\":\"SubtitleENGroup\"}" }, "Type" : "SubtitleGroup" }
Group:指定音频分组名称为SubtitleENGroup。
Lang: 指定此字幕组的语言。
Type:类型为SubtitleGroup活动。
提取字幕。
上传STL、TTML、WebVtt格式的字幕到OSS中。
活动定义:
"subtitleCNNode" : { "Name" : "subtitleCNNode", "Parameters" : { "InputConfig" : "{\"Format\":\"vtt\",\"InputFile\":{\"URL\":\"http://exampleBucket****.oss-cn-hangzhou.aliyuncs.com/test/Audio-SiHD.chs.vtt\"}}", "Representation" : "{\"Id\":\"subtitle-chinese\", \"URI\":\"subtitle/cn-xx.vtt\"}" }, "Type" : "Transcode" }
InputConfig指定字幕地址,字幕地址在调用新增媒体时可以被动态覆盖,见参数OverrideParams。
URI: 字幕流提取后的名称及输出目录。
Type设置为Transcode,即转码活动。
输出Master Playlist。
通过提取音频、视频、字幕,将所有提取转换后的资源打包成一个Master Playlist。
活动定义:
{ "Parameters" : { }, "Type" : "GenerateMasterPlayList" }
Type设置为GenerateMasterPlayList,即生成Master Playlist活动。
拓扑图示意:
完整的场景示例用拓扑结构表示:
{
"Activities": {
"act-package": {
"Name": "act-package",
"Parameters": {
"Output": "{\"Bucket\": \"outputbucketname\",\"Location\": \"oss-cn-hangzhou\",\"MasterPlayListName\": \"dashpackage/{MediaId}/{RunId}/master.mpd\"}",
"Protocol": "dash"
},
"Type": "PackageConfig"
},
"video-group": {
"Name": "video-group",
"Parameters": {
"AdaptationSet": "{\"Group\":\"VideoGroup\"}"
},
"Type": "VideoGroup"
},
"audio-en-group": {
"Name": "audio-en-group",
"Parameters": {
"AdaptationSet": "{\"Lang\":\"english\", \"Group\":\"AudioGroupEnglish\"}"
},
"Type": "AudioGroup"
},
"audio-cn-group": {
"Name": "audio-cn-group",
"Parameters": {
"AdaptationSet": "{\"Lang\":\"chinese\", \"Group\":\"AudioGroupChinese\"}"
},
"Type": "AudioGroup"
},
"subtitle-en-group": {
"Name": "subtitle-en-group",
"Parameters": {
"AdaptationSet": "{\"Lang\":\"english\", \"Group\":\"SubtitleENGroup\"}"
},
"Type": "SubtitleGroup"
},
"subtitle-cn-group": {
"Name": "subtitle-cn-group",
"Parameters": {
"AdaptationSet": "{\"Lang\":\"chinese\", \"Group\":\"SubtitleCNGroup\"}"
},
"Type": "SubtitleGroup"
},
"videoTransLD": {
"Name": "videoTransLD",
"Parameters": {
"Outputs": "[{\"TemplateId\":\"d053297fc44f9dd6becd4a98d1c42f50\",\"Audio\":{\"Remove\":\"true\"}}]",
"Representation": "{\"Id\":\"270pLD\", \"URI\":\"videoLD/xx.mpd\"}"
},
"Type": "Transcode"
},
"videoTransSD": {
"Name": "videoTransSD",
"Parameters": {
"Outputs": "[{\"TemplateId\":\"d861b90f6c0aed8f81095e5c5b85****\",\"Audio\":{\"Remove\":\"true\"}}]",
"Representation": "{\"Id\":\"480pSD\", \"URI\":\"videoSD/****.mpd\"}"
},
"Type": "Transcode"
},
"videoTransHD": {
"Name": "videoTransHD",
"Parameters": {
"Outputs": "[{\"TemplateId\":\"117b3ae88efbc97df372cfd9a0e1****\",\"Audio\":{\"Remove\":\"true\"}}]",
"Representation": "{\"Id\":\"720pHD\", \"URI\":\"videoHD/****.mpd\"}"
},
"Type": "Transcode"
},
"audioCNTransNode": {
"Name": "audioCNTransNode",
"Parameters": {
"Outputs": "[{\"TemplateId\":\"d053297fc44f9dd6becd4a98d1c4****\",\"AudioStreamMap\":\"0:a:0\",\"Video\":{\"Remove\":\"true\"}}]",
"Representation": "{\"Id\":\"chinese128k\", \"URI\":\"audiocn/cn-abc.mpd\"}"
},
"Type": "Transcode"
},
"audioENTransNode": {
"Name": "audioENTransNode",
"Parameters": {
"Outputs": "[{\"TemplateId\":\"d053297fc44f9dd6becd4a98d1c4****\",\"AudioStreamMap\":\"0:a:1\",\"Video\":{\"Remove\":\"true\"}}]",
"Representation": "{\"Id\":\"english128k\", \"URI\":\"audioen/en-abc.mpd\"}"
},
"Type": "Transcode"
},
"subtitleENNode": {
"Name": "subtitleENNode",
"Parameters": {
"InputConfig": "{\"Format\":\"vtt\",\"InputFile\":{\"URL\":\"http://exampleBucket****.oss-cn-hangzhou.aliyuncs.com/dashpackage/subtitle/Subtitle****.EN.vtt\"}}",
"Representation": "{\"Id\":\"subtitle-english\", \"URI\":\"subtitle/en-****.vtt\"}"
},
"Type": "Transcode"
},
"subtitleCNNode": {
"Name": "subtitleCNNode",
"Parameters": {
"InputConfig": "{\"Format\":\"vtt\",\"InputFile\":{\"URL\":\"http://exampleBucket****.oss-cn-hangzhou.aliyuncs.com/dashpackage/subtitle/Subtitle.CN.vtt\"}}",
"Representation": "{\"Id\":\"subtitle-chinese\", \"URI\":\"subtitle/cn-****.vtt\"}"
},
"Type": "Transcode"
},
"act-report": {
"Name": "act-report",
"Parameters": {
"PublishType": "Auto"
},
"Type": "Report"
},
"act-start": {
"Name": "act-start",
"Parameters": {
"PipelineId": "cc7fcef2562e4abc9332d491f933****",
"InputFile": "{\"Bucket\":\"exampleBucket****\",\"Location\":\"oss-cn-hangzhou\",\"ObjectPrefix\":\"package/dash/\"}"
},
"Type": "Start"
},
"generateMasterPlayListAct": {
"Name": "generateMasterPlayListAct",
"Parameters": {},
"Type": "GenerateMasterPlayList"
}
},
"Dependencies": {
"audio-en-group": ["audioENTransNode"],
"video-group": ["videoTransLD", "videoTransSD", "videoTransHD"],
"audio-cn-group": ["audioCNTransNode"],
"audioCNTransNode": ["generateMasterPlayListAct"],
"subtitleENNode": ["generateMasterPlayListAct"],
"act-package": ["audio-en-group", "audio-cn-group", "subtitle-cn-group", "subtitle-en-group", "video-group"],
"act-report": [],
"videoTransSD": ["generateMasterPlayListAct"],
"videoTransHD": ["generateMasterPlayListAct"],
"subtitle-en-group": ["subtitleENNode"],
"subtitle-cn-group": ["subtitleCNNode"],
"subtitleCNNode": ["generateMasterPlayListAct"],
"act-start": ["act-package"],
"videoTransLD": ["generateMasterPlayListAct"],
"generateMasterPlayListAct": ["act-report"],
"audioENTransNode": ["generateMasterPlayListAct"]
}
}
示例代码
新建DASH打包工作流。
新增媒体。