すべてのプロダクト
Search
ドキュメントセンター

ApsaraVideo Live:ライブストリームカプセル化

最終更新日:Feb 05, 2026

ライブストリームカプセル化は、ライブストリームをさまざまなコンテナフォーマットに変換し、低遅延でさまざまなストリーミングプロトコルを介して再生できるようにします。

サポートされているコンテナフォーマット

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 操作を呼び出すことで、カプセル化設定を作成します。

説明

進行中のストリームの場合、設定はストリームを再インジェストした後にのみ有効になります。

コンソール

  1. ApsaraVideo Live コンソールにログインします。

  2. 左側のナビゲーションウィンドウで、機能管理 > ライブストリームのカプセル化 を選択します。

  3. ストリーミングドメインを選択し、次に 追加 をクリックします。

  4. [カプセル化設定] ダイアログボックスで、次のパラメーターを設定します。

    パラメーター

    説明

    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

    トランスコードされたストリームをカプセル化するかどうかを指定します。有効値:

    • ソースストリームのみ

    • トランスコードされたストリームを含む

    説明

    ストリーミングドメインが中国本土以外のライブセンター (シンガポール、ドイツ、日本、またはインドネシア) を使用している場合、再生遅延が増加する可能性があります。本番環境での使用前に設定をテストしてください。

  5. [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) を次の推奨設定で使用します。

image.png

カプセル化されたストリームの再生

  1. ストリーミング 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

  2. 互換性のあるプレーヤーでストリームを再生します。ApsaraVideo Player を推奨します。

    ApsaraVideo Player Web デモを使用するには:image

    a. [ビデオタイプ][ブロードキャスト] に設定します。

    b. ストリーミング URL を入力します。

    c. [プレビュー] タブをクリックしてビデオをプレビューします。

    重要

    ApsaraVideo Player Web バージョンを使用するには、HTTPS 証明書を設定し、クロスドメインアクセス用に Access-Control-Allow-Origin ヘッダーを設定する必要があります。詳細については、「HTTPS 設定」および「HTTP ヘッダーの設定」をご参照ください。

高度な使用法

トランスコードされたストリームのカプセル化

カプセル化とトランスコーディングを組み合わせて、トランスコードされたストリームをパッケージ化できます。

手順

  1. ソースストリームのトランスコーディングを設定します。詳細については、「ライブストリームトランスコーディング」をご参照ください。

  2. カプセル化設定を作成する際に、コンソールで [Transcoded Stream][Transcoded Stream Included] に設定するか、AddLivePackageConfig API を介して IgnoreTranscodefalse に設定します。

    // Include transcoded streams in encapsulation process (default: true = exclude)
    addLivePackageConfigRequest.setIgnoreTranscode(false);
  3. カプセル化されたトランスコードストリームのストリーミング 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 を生成します。

  4. 互換性のあるプレーヤーでストリームを再生します。

カプセル化されたストリームのタイムシフト

カプセル化されたストリームでタイムシフトを使用できます。詳細については、「タイムシフト」をご参照ください。

タイムシフトが有効になっている場合、タイムシフトされたセグメントのフォーマットは、カプセル化設定で指定されたセグメントの長さとフォーマットを継承します。

  • HLS または LL-HLS (CMAF): タイムシフトされたセグメントは CMAF フォーマットです。

  • LL-HLS (TS): タイムシフトされたセグメントは TS フォーマットです。

API リファレンス

ライブストリームカプセル化 API 操作