阿里云視頻直播支持直播封裝服務,支持封裝HLS、DASH、LL-HLS(低延遲HLS)等播放協議,支持TS,CMAF切片格式。通過閱讀本文,您可以了解直播封裝服務的詳細信息。
簡介
阿里云基礎直播服務提供RTMP、HTTP-FLV、HLS等播放協議。為支持更豐富、更低延遲的播放協議和體驗,視頻直播新增了直播封裝服務,根據不同的切片類型支持低延遲HLS-TS、低延遲HLS-CMAF、HLS-CMAF、DASH-CMAF、HLS&DASH-CMAF封裝協議,如下所示:
切片類型 | 支持的封裝協議 | 支持的編碼格式 |
TS | 低延遲HLS-TS |
|
CMAF |
|
|
低延遲HLS-TS會以TS格式封裝低延遲HLS協議,低延遲HLS-CMAF會以CMAF格式封裝低延遲HLS協議,其他情況以此類推。
功能及優勢
使用場景
低延遲直播:直播服務提供HLS播放地址,在您的業務場景中如果需要在支持HLS協議的情況下降低延遲,可以對HLS協議進行封裝,使用LL-HLS(低延遲HLS)協議。
多設備瀏覽器支持:直播服務提供的HLS播放地址默認采用TS切片格式進行封裝,如果TS切片格式不能滿足您的業務需求,您可以通過封裝功能使用CMAF封裝格式進行封裝,適配更多的設備和瀏覽器。
注意事項
為了CMAF和低延遲HLS播放流暢,推流需確保GOP大小穩定,且直播封裝切片時長為GOP時長的整數倍。如封裝配置包含轉碼流,也需確保轉碼流的GOP穩定。對于低延遲HLS:
在網絡情況不佳時卡頓率會增高,建議與多碼率轉碼組合使用,網絡不佳時自動降低碼率。
需要確保直播流GOP固定為1秒或2秒,否則會導致卡頓或播放失敗。
需使用支持LL-HLS的播放器,如AliPlayer、hls.js、ExoPlayer等,建議使用AliPlayer。
同一主播流域名最大支持直播觀看人數為10萬人,如需支持更多人觀看,請提交工單申請。
域名第一次添加封裝配置時,會同步下發播放域名加速相關配置,3~5分鐘后可生效。
功能使用
配置直播封裝
視頻直播目前支持兩種方式進行直播封裝功能配置。
- 登錄視頻直播控制臺。
在左側導航欄單擊功能管理>直播封裝。
單擊您要配置的播流域名,單擊添加。
直播封裝配置參數及說明如下表所示。
參數
描述
AppName
AppName必須與推流地址中的AppName名稱一樣,封裝配置才能生效。
AppName不超過256字符,支持數字、大小寫字母、短劃線(-)、下劃線(_)。
AppName也支持輸入單個星號(*)字符,表示匹配任意字符串(包括空字符串)。
StreamName
StreamName必須與推流地址中的StreamName名稱一樣,封裝配置才能生效。
StreamName不超過256字符,支持數字、大小寫字母、短劃線(-)、下劃線(_)。
StreamName也支持輸入單個星號(*)字符,表示匹配任意字符串(包括空字符串)。
協議配置
選擇封裝協議,可選:
HLS - CMAF
低延遲HLS - CMAF
低延遲HLS - TS
DASH-CMAF
說明只支持DASH
HLS&DASH-CMAF
說明DASH和HLS都支持
切片個數
選擇配置的切片個數,支持輸入范圍3~5的整數。
切片時長
當協議配置選擇HLS - CMAF、DASH-CMAF、HLS&DASH-CMAF時,取值范圍為1~10的整數,單位s。固定GOP,建議GOP為5s,需要保證切片時長為GOP的整數倍。
當協議配置選擇低延遲HLS - CMAF和低延遲HLS - TS時,取值范圍為1~2的整數,單位s。固定GOP,建議GOP為1s,需要保證切片時長為GOP的整數倍。
part切片時長
僅封裝協議選擇低延遲HLS - CMAF和低延遲HLS - TS,需要配置part切片時長。取值范圍為200-1000的整數,單位ms。建議略大于切片時長的1/3。
轉碼流
可選僅配置原始流和包含轉碼流。
說明若AppName/StreamName匹配的視頻流配置了直播時移功能,直播時移的切片時長和格式,會按照封裝配置的切片時長和格式生效。
若AppName/StreamName匹配的視頻流配置了多碼率轉碼,多碼率HLS直播的切片時長和格式,會按照封裝配置的切片時長和格式生效。
若播放域名對應的區域為海外區域時(新加坡、德國、日本、印尼),可能會存在延遲較大的問題 ,建議配置完成后請先測試驗證是否符合預期。
配置參數后,單擊確定。
//需要<>內容替換成實際使用的值
DefaultProfile profile = DefaultProfile.getProfile("<regionId>", "<ALIBABA_CLOUD_ACCESS_KEY_ID>", "<ALIBABA_CLOUD_ACCESS_KEY_SECRET>");
IAcsClient client = new DefaultAcsClient(profile);
AddLivePackageConfigRequest addLivePackageConfigRequest = new AddLivePackageConfigRequest();
addLivePackageConfigRequest.setDomainName("<DomainName>");
//AppName不超過256字符,支持數字、大小寫字母、短劃線(-)、下劃線(_)。
//AppName也支持輸入單個星號(*)字符,表示匹配任意字符串(包括空字符串)。
addLivePackageConfigRequest.setAppName("<AppName>");
//StreamName不超過256字符,支持數字、大小寫字母、短劃線(-)、下劃線(_)。
//StreamName也支持輸入單個星號(*)字符,表示匹配任意字符串(包括空字符串)。
addLivePackageConfigRequest.setStreamName("<StreamName>");
//直播協議與封裝格式。
addLivePackageConfigRequest.setBizProtocol("<Protocol>");
//直播M3U8切片個數,支持輸入范圍3~5的整數。
addLivePackageConfigRequest.setSegmentNum(<3>);
//切片時長,單位:秒。
//封裝協議為低延遲HLS時,取值范圍為1~2的整數,單位s。固定GOP,建議GOP為1s,需要保證切片時長為GOP的整數倍。
//封裝協議為HLS或DASH時,取值范圍為1~10的整數,單位s。固定GOP,建議GOP為5s,需要保證切片時長為GOP的整數倍。
addLivePackageConfigRequest.setSegmentDuration(<5>);
//Part切片時長,僅在封裝協議包含低延遲HLS時有效。取值范圍為200-1000的整數,單位ms。建議略大于切片時長的1/3。
addLivePackageConfigRequest.setPartDuration(<350>);
//是否忽略轉碼流,默認值true。
addLivePackageConfigRequest.setIgnoreTranscode(<true>);
try {
AddLivePackageConfigResponse addLivePackageConfigResponse = client.getAcsResponse(addLivePackageConfigRequest);
System.out.println(new Gson().toJson(addLivePackageConfigResponse));
// todo something.
} catch (ServerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClientException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
<Protocol>取值以及更多接口說明請參見AddLivePackageConfig。
使用JAVA SDK,具體請參見Java SDK使用說明。
重新推流配置才能生效。
配置協議封裝的情況下,原畫播流地址仍然可以正常使用。
使用直播封裝
推流
在使用直播封裝功能時,為了CMAF和低延遲HLS播放流暢,推流需確保GOP大小穩定。
OBS推流可參考如下設置(關于OBS更多使用信息,請參見OBS推流工具):
播放
對于不同的封裝協議,需使用不同的播放地址。各封裝協議播放地址示例如下:
封裝協議 | 地址示例 |
HLS |
|
DASH |
|
低延遲HLS |
|
在播放封裝流時,
aliyunols=on
為必填固定參數。各封裝格式提供的協議地址如下:
低延遲HLS-TS:低延遲HLS地址和HLS地址。
低延遲HLS-CMAF:低延遲HLS地址和HLS地址。
HLS-CMAF:HLS地址。
DASH-CMAF:DASH地址。
HLS&DASH-CMAF:HLS地址和DASH地址。
推薦您使用阿里云播放器,關于阿里云播放器說明請參見播放器SDK。
您可以參考以下示例使用Web端阿里云播放器播放:
選擇播放類型為直播。
輸入播放地址。
點擊播放預覽進行播放。
為支持瀏覽器跨域播放,需要配置HTTP頭
Access-Control-Allow-Origin
,詳情請參見配置HTTP消息頭。
進階使用
封裝轉碼流
直播封裝功能可以結合轉碼功能使用,對轉碼流進行協議封裝。
封裝轉碼流,需要先完成直播轉碼功能配置,具體操作請參見直播轉碼。
此處假設您已完成轉碼功能配置。
在進行封裝配置時,將轉碼流也進行封裝。
//是否忽略轉碼流,true/false,默認值true
addLivePackageConfigRequest.setIgnoreTranscode(<false>);
播放封裝轉碼流只需要將封裝協議地址StreamName替換成StreamName
加_轉碼模板ID
的形式。
例如現在要播放一個低延遲HLS的轉碼流,示例地址如下:
http://<DomainName>/<AppName>/<StreamName_轉碼模板ID>-llhls.m3u8?aliyunols=on&auth_key=1725503******
建議您可以將封裝功能與多碼率轉碼功能結合使用,在網絡不佳時自動調整碼率播放。
播放封裝多碼率轉碼流只需將StreamName替換成
StreamName
加_轉碼模板組ID
的形式。
封裝多碼率轉碼流,轉碼流地址會按照直播封裝指定的協議和切片格式改變(例如指定封裝格式為DASH-CMAF,多碼率轉碼將只會提供DASH轉碼流地址,不會提供HLS轉碼流地址)。
封裝通用轉碼或自定義轉碼流,轉碼流地址不受影響,會另外增加轉碼流的封裝地址。
封裝地址請參見本文檔播放封裝流相關內容。
時移播放封裝流
直播時移功能可以讓直播觀眾在直播過程中回看直播內容,直播封裝功能可與直播時移功能組合使用,詳情可參見直播時移。
如果開啟了直播時移,時移的封裝格式將采用直播封裝指定的切片長度和格式。對于HLS或低延遲HLS-CMAF格式,直播時移切片也將變成CMAF格式;對于低延遲HLS-TS格式,直播時移切片仍為TS格式。
相關文檔
更多直播封裝相關API,請參見直播封裝相關接口。