ライブストリームカプセル化は、ライブストリームをさまざまなコンテナフォーマットに変換し、低遅延でさまざまなストリーミングプロトコルを介して再生できるようにします。
サポートされているコンテナフォーマット
ApsaraVideo Live は、Real-Time Messaging Protocol (RTMP)、HTTP-FLV、および HTTP Live Streaming (HLS) をサポートしています。遅延を減らし、互換性を向上させるために、ライブストリームカプセル化は、配信前にクラウドでストリームをさまざまなコンテナフォーマットに変換します。
サポートされているコンテナフォーマットを次の表に示します。
コンテナフォーマット | サポートされているストリーミングプロトコル | サポートされているコーデック |
TS | Low-Latency HLS (LL-HLS) | オーディオ: AAC、OPUS、AC3、EAC3、MP3 ビデオ: H.264、H.265 |
CMAF | LL-HLS、HLS、DASH | オーディオ: AAC ビデオ: H.264、H.265 |
仕組み
ライブストリームカプセル化は、ストリームを TS または CMAF フォーマットのセグメントに分割します。その後、システムは HLS、LL-HLS、または DASH プロトコルを介してセグメントを配信します。各ストリームについて、システムはセグメント URL を順番に記録するマニフェストファイルを生成します。クライアントがライブストリームをリクエストすると、サーバーは最新のマニフェストを返します。
この機能は、ライブストリームトランスコーディングおよびタイムシフトと組み合わせて、ストリーミング体験を向上させることができます。
利点
低遅延ライブストリーミングの実装
標準 HLS と比較して、LL-HLS はストリームをより小さな部分セグメント (200 ミリ秒から 1 秒) に分割します。このアプローチにより、プレイリストの再読み込みがブロックされ、エンドツーエンド遅延が3 ~ 5 秒に短縮されます。
複数のデバイスとの互換性の向上
デフォルトでは、ApsaraVideo Live は TS コンテナフォーマットを使用して HLS 経由でライブストリームを配信します。このフォーマットは一部のデバイスやブラウザと互換性がありません。カプセル化を使用してコンテンツを CMAF フォーマットにパッケージ化すると、より広範なデバイス、プラットフォーム、およびコーデック (H.265 を含む) をサポートできます。
制限事項
GOP サイズ
インジェストストリームの GOP サイズは一貫している必要があります。トランスコードされたストリームをカプセル化する場合、その GOP サイズも安定していることを確認してください。
各セグメント期間は GOP サイズの倍数である必要があります。
LL-HLS プロトコル
ネットワーク状況が悪い場合、カクつきが増加する可能性があります。ビットレートを自動的に調整するマルチビットレートトランスコーディングとカプセル化を組み合わせて使用することを推奨します。
カクつきや再生失敗を防ぐために、GOP サイズを 1 または 2 秒に設定してください。
メインストリーミングドメインは最大 100,000 人の視聴者をサポートできます。このクォータを増やすには、チケットを送信してください。
設定伝播
カプセル化設定を初めて追加すると、システムはコンテンツ配信設定を更新します。これらの変更が有効になるまでには 3 ~ 5 分かかります。
カプセル化設定の作成
コンソールまたは API 操作を呼び出すことで、カプセル化設定を作成します。
進行中のストリームの場合、設定はストリームを再インジェストした後にのみ有効になります。
コンソール
ApsaraVideo Live コンソールにログインします。
左側のナビゲーションウィンドウで、機能管理 > ライブストリームのカプセル化 を選択します。
ストリーミングドメインを選択し、次に 追加 をクリックします。
[カプセル化設定] ダイアログボックスで、次のパラメーターを設定します。
パラメーター
説明
AppName
すべてのアプリーケーションに適用するには、アスタリスク (
*) を入力します。特定のアプリケーションをターゲットにするには、アップストリーミング URL からAppNameを入力します。StreamName
すべてのストリームに適用するには、アスタリスク (
*) を入力します。特定のストリームをターゲットにするには、ストリーム名を入力します。Protocol
コンテナフォーマットと再生プロトコルを選択します。有効値:
HLS - CMAF
LL-HLS - CMAF
LL-HLS - TS
DASH - CMAF
HLS & DASH - CMAF
Segment Quantity
マニフェストファイルあたりのセグメント数を指定します。有効値: 3 ~ 5。
Segment Length (s)
HLS または DASH の場合: 1 ~ 10 の整数を入力します。GOP サイズの倍数に設定してください (推奨 GOP: 5 秒)。
LL-HLS の場合: 1 または 2 を入力します。GOP サイズの倍数に設定してください (推奨 GOP: 1 秒)。
Part Length (ms)
(LL-HLS のみ) 部分セグメントの期間を指定します。有効値: 200 ~ 1,000。セグメントの長さの 3 分の 1 よりわずかに大きい値を推奨します。
Transcoded Stream
トランスコードされたストリームをカプセル化するかどうかを指定します。有効値:
ソースストリームのみ
トランスコードされたストリームを含む
説明ストリーミングドメインが中国本土以外のライブセンター (シンガポール、ドイツ、日本、またはインドネシア) を使用している場合、再生遅延が増加する可能性があります。本番環境での使用前に設定をテストしてください。
[OK] をクリックします。
API
AddLivePackageConfig API を呼び出して、カプセル化設定を追加します。
<Your RegionId>、<Your DomainName>、<Your AppName>、および <Your StreamName> を含むプレースホルダーを置き換えます。
有効なプロトコル値については、「AddLivePackageConfig」をご参照ください。
サンプルコード
// このファイルは自動生成されたものです。編集しないでください。
package demo;
import com.aliyun.auth.credentials.Credential;
import com.aliyun.auth.credentials.provider.StaticCredentialProvider;
import com.aliyun.core.http.HttpClient;
import com.aliyun.core.http.HttpMethod;
import com.aliyun.core.http.ProxyOptions;
import com.aliyun.httpcomponent.httpclient.ApacheAsyncHttpClientBuilder;
import com.aliyun.sdk.service.live20161101.models.*;
import com.aliyun.sdk.service.live20161101.*;
import com.google.gson.Gson;
import darabonba.core.RequestConfiguration;
import darabonba.core.client.ClientOverrideConfiguration;
import darabonba.core.utils.CommonUtil;
import darabonba.core.TeaPair;
//import javax.net.ssl.KeyManager;
//import javax.net.ssl.X509TrustManager;
import java.net.InetSocketAddress;
import java.time.Duration;
import java.util.*;
import java.util.concurrent.CompletableFuture;
import java.io.*;
public class AddLivePackageConfig {
public static void main(String[] args) throws Exception {
// HttpClient の設定
/*HttpClient httpClient = new ApacheAsyncHttpClientBuilder()
.connectionTimeout(Duration.ofSeconds(10)) // 接続タイムアウト時間を設定します。デフォルトは 10 秒です。
.responseTimeout(Duration.ofSeconds(10)) // 応答タイムアウト時間を設定します。デフォルトは 20 秒です。
.maxConnections(128) // 接続プールサイズを設定します。
.maxIdleTimeOut(Duration.ofSeconds(50)) // 接続プールのタイムアウトを設定します。デフォルトは 30 秒です。
// プロキシを設定します。
.proxy(new ProxyOptions(ProxyOptions.Type.HTTP, new InetSocketAddress("<YOUR-PROXY-HOSTNAME>", 9001))
.setCredentials("<YOUR-PROXY-USERNAME>", "<YOUR-PROXY-PASSWORD>"))
// https 接続の場合は、証明書を設定するか、証明書を無視 (.ignoreSSL(true)) する必要があります。
.x509TrustManagers(new X509TrustManager[]{})
.keyManagers(new KeyManager[]{})
.ignoreSSL(false)
.build();*/
// ak、secret、token などの Credentials 認証情報を設定します。
StaticCredentialProvider provider = StaticCredentialProvider.create(Credential.builder()
// 環境変数 ALIBABA_CLOUD_ACCESS_KEY_ID と ALIBABA_CLOUD_ACCESS_KEY_SECRET が設定されていることを確認してください。
.accessKeyId(System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"))
.accessKeySecret(System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET"))
//.securityToken(System.getenv("ALIBABA_CLOUD_SECURITY_TOKEN")) // STS トークンを使用
.build());
// Client を設定します。
AsyncClient client = AsyncClient.builder()
.region("<Your RegionId>") // リージョン ID
//.httpClient(httpClient) // 設定済みの HttpClient を使用します。設定しない場合は、デフォルトの HttpClient (Apache HttpClient) が使用されます。
.credentialsProvider(provider)
//.serviceConfiguration(Configuration.create()) // サービスレベルの設定
// クライアントレベルの設定を上書きし、Endpoint、Http リクエストパラメーターなどを設定できます。
.overrideConfiguration(
ClientOverrideConfiguration.create()
// エンドポイントの詳細については、https://api.alibabacloud.com/product/live をご参照ください。
.setEndpointOverride("live.aliyuncs.com")
//.setConnectTimeout(Duration.ofSeconds(30))
)
.build();
// API リクエストのパラメーター設定
AddLivePackageConfigRequest addLivePackageConfigRequest = AddLivePackageConfigRequest.builder()
.regionId("<Your RegionId>")
.domainName("<Your DomainName>")
.appName("<Your AppName>")
.streamName("<Your StreamName>")
// リクエストレベルの設定を上書きし、Http リクエストパラメーターなどを設定できます。
// .requestConfiguration(RequestConfiguration.create().setHttpHeaders(new HttpHeaders()))
.build();
// API リクエストの戻り値を非同期に取得します。
CompletableFuture<AddLivePackageConfigResponse> response = client.addLivePackageConfig(addLivePackageConfigRequest);
// API リクエストの戻り値を同期的に取得します。
AddLivePackageConfigResponse resp = response.get();
System.out.println(new Gson().toJson(resp));
// 戻り値の非同期処理
/*response.thenAccept(resp -> {
System.out.println(new Gson().toJson(resp));
}).exceptionally(throwable -> { // 例外の処理
System.out.println(throwable.getMessage());
return null;
});*/
// 最後に、クライアントを閉じます。
client.close();
}
}SDK セットアップ手順については、「Java SDK の使用」をご参照ください。
設定後も、元の品質のストリーミング URL にアクセスできます。
カプセル化されたストリームのインジェストと再生
ストリームのインジェスト
スムーズな再生のために、インジェストストリームの GOP サイズを一貫して維持してください。
Open Broadcaster Software (OBS) を次の推奨設定で使用します。

カプセル化されたストリームの再生
ストリーミング URL を取得します。フォーマットはプロトコルによって異なります。
プロトコル
URL フォーマット
HLS
http://<DomainName>/<AppName>/<StreamName>.m3u8?aliyunols=on&auth_key=<AuthKey>DASH
http://<DomainName>/<AppName>/<StreamName>.mpd?aliyunols=on&auth_key=<AuthKey>LL-HLS
http://<DomainName>/<AppName>/<StreamName>-llhls.m3u8?aliyunols=on&auth_key=<AuthKey>重要カプセル化されたストリーム URL には、
aliyunols=onパラメーターが必要です。ストリーミング URL の生成には、URL ジェネレーターを使用できます。URL フォーマットは設定によって異なります。
コンテナフォーマット
プロトコル
生成される URL タイプ
TS
LL-HLS
LL-HLS および HLS
CMAF
LL-HLS
LL-HLS および HLS
CMAF
HLS
HLS
CMAF
DASH
DASH
CMAF
HLS & DASH
HLS および DASH
互換性のあるプレーヤーでストリームを再生します。ApsaraVideo Player を推奨します。
ApsaraVideo Player Web デモを使用するには:

a. [ビデオタイプ] を [ブロードキャスト] に設定します。
b. ストリーミング URL を入力します。
c. [プレビュー] タブをクリックしてビデオをプレビューします。
重要ApsaraVideo Player Web バージョンを使用するには、HTTPS 証明書を設定し、クロスドメインアクセス用に
Access-Control-Allow-Originヘッダーを設定する必要があります。詳細については、「HTTPS 設定」および「HTTP ヘッダーの設定」をご参照ください。
高度な使用法
トランスコードされたストリームのカプセル化
カプセル化とトランスコーディングを組み合わせて、トランスコードされたストリームをパッケージ化できます。
手順
ソースストリームのトランスコーディングを設定します。詳細については、「ライブストリームトランスコーディング」をご参照ください。
カプセル化設定を作成する際に、コンソールで [Transcoded Stream] を [Transcoded Stream Included] に設定するか、AddLivePackageConfig API を介して
IgnoreTranscodeをfalseに設定します。// Include transcoded streams in encapsulation process (default: true = exclude) addLivePackageConfigRequest.setIgnoreTranscode(false);カプセル化されたトランスコードストリームのストリーミング URL を生成します。
デフォルトまたはカスタムのトランスコーディングテンプレート:
StreamNameに_<template-id>を追加します。例:http://<DomainName>/<AppName>/<StreamName>_<template-id>-llhls.m3u8?aliyunols=on&auth_key=<AuthKey>マルチビットレートトランスコーディングテンプレート:
StreamNameに_<template-group-id>を追加します。
説明カプセル化とマルチビットレートトランスコーディングを組み合わせることで、アダプティブ再生が可能になり、プレーヤーはネットワーク状況が悪い場合に自動的に低いビットレートに切り替えることができます。
出力 URL の動作は、使用されるトランスコーディングテンプレートのタイプによって異なります。
マルチビットレートトランスコーディングの場合:
カプセル化設定は、トランスコードされたストリームの出力フォーマットを上書きします。たとえば、
DASH - CMAFのカプセル化フォーマットを指定した場合、システムはマルチビットレートストリームに対して DASH - CMAF URL のみを生成し、HLS URL は生成しません。デフォルトまたはカスタムのトランスコーディングの場合:
元のトランスコードストリーム URL は影響を受けません。代わりに、システムはこれらのトランスコードストリームに対して追加のカプセル化された URL を生成します。
互換性のあるプレーヤーでストリームを再生します。
カプセル化されたストリームのタイムシフト
カプセル化されたストリームでタイムシフトを使用できます。詳細については、「タイムシフト」をご参照ください。
タイムシフトが有効になっている場合、タイムシフトされたセグメントのフォーマットは、カプセル化設定で指定されたセグメントの長さとフォーマットを継承します。
HLS または LL-HLS (CMAF): タイムシフトされたセグメントは CMAF フォーマットです。
LL-HLS (TS): タイムシフトされたセグメントは TS フォーマットです。