19
6

More than 3 years have passed since last update.

S3に配置した動画をMediaLiveでスケジュール組んで配信してみる

Posted at

この記事は NewsPicks Advent Calendar 2019 の8日目の記事です。

はじめに

こんにちは、NewsPicksでサーバーサイドエンジニアをしている@d-kumoです。

NewsPicksというとオリジナル記事等の文字ベースのコンテンツをイメージされる方も多いかと思いますが、動画コンテンツにも力を入れており、今では週に4回配信することもあります。
今後増えていく動画コンテンツをより安定的に配信するため、最近はいろんな配信技術に触れる機会も増えてきました。

そんな中で、今回はAWSが提供しているライブ配信サービスAWS Elemental MediaLiveを使った配信構成を試してみたのでご紹介したいと思います。

※NewsPicksの動画配信構成については、以下の記事で解説しています。ご興味のある方はご覧ください。
https://qiita.com/kirihata/items/c027c7561eead3b1dced

MediaLiveとは

AWS Elemental MediaLiveとは、入力された動画データをリアルタイムにエンコードして出力してくれるサービスです。
入力として使える動画データは、撮影中のカメラ等から転送されてきたものはもちろんのこと、S3に配置されているmp4ファイルを使うこともできます。

ただ、このサービスはエンコードしてくれるだけなので、動画配信は他のサービスと連携して行う必要があります。
例えば、AWS Elemental MediaStoreというメディア向けにチューニングされたストレージサービスをMediaLiveの出力先に指定し、そこでエンコードされたコンテンツを保存、配信するような形です。

やりたいこと

既に収録済みである動画を配信します。

具体的には以下の通りです。

  • 配信構成は、MediaLive→MediaStore(冗長性は考えない)
  • 入力は、S3にアップロードしたmp4ファイル
  • 配信スケジュールは以下
    • 2019/12/8 21:45から予告映像を配信する(ループ再生)
    • 2019/12/8 22:00になったら本編映像を配信する
    • 本編終了後、配信が終了した旨の映像を配信する(ループ再生)

ざっくりやること

やりたいことを実現するため、以下の設定をします。

  • S3に動画ファイルを配置
  • MediaStoreでコンテナ作成
  • MediaLiveでInput作成
  • MediaLiveでChannel作成
  • MediaLiveでスケジュール設定

やってみる

S3に動画ファイルを配置

S3の適当なパスに配信したいmp4ファイルを配置します。

今回は、予告動画、本編動画、終了後動画の3本を配置しています。

スクリーンショット 2019-12-05 18.15.04.png

MediaStoreでコンテナ作成

MediaLiveからの配信を受けるコンテナを作成します。

コンテナ作成

Create containerからコンテナを作成します。

スクリーンショット 2019-12-05 17.48.00.png

Container policyを設定

公式ドキュメントを参考にポリシーを設定してアクセスできるようにします。

HTTPS通信であれば誰でもアクセスを許可するのであれば、以下の通りです。
<region><owner acct number><container name>には適当なものを入れてください。

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Sid": "PublicReadOverHttps",
      "Effect": "Allow",
      "Action": ["mediastore:GetObject", "mediastore:DescribeObject"],
      "Principal": "*",
      "Resource": "arn:aws:mediastore:<region>:<owner acct number>:container/<container name>/*",
      "Condition": {
        "Bool": {
            "aws:SecureTransport": "true"
        }
      }
    }
  ]
}

MediaLiveのInput作成

MediaLiveへの入力として、S3に配置したmp4ファイルを設定します。

Create inputでinput作成画面を開きます。

スクリーンショット 2019-12-05 18.33.06.png

Inputの名前、入力するファイル形式(今回はmp4)を入力します。

スクリーンショット 2019-12-05 18.05.50.png

ソースのパスを指定してCreate
(Input source Aだけ入力すれば大丈夫です。)

スクリーンショット 2019-12-05 18.22.22.png

配信する3つの動画ファイルについて、それぞれ作成します。

MediaLiveのChannel作成

配信チャンネルを作成します。(これが中々大変です。。)

Create channelでChannel作成画面を開きます。

スクリーンショット 2019-12-05 18.42.37.png

Channel and input details

General info

Channel名とIAMロールを設定します。

スクリーンショット 2019-12-05 21.41.31.png

Channel template

既存のテンプレートであるLive event(HLSの方)を設定します。

スクリーンショット 2019-12-05 21.42.06.png

すると、Output groupsにHLS形式の出力設定が追加されます。

Channel class

ここはSINGLE_PIPELINEを設定します。

デフォルト設定であるSTANDARDを使うと、Multi-AZで構成される2つのパイプラインを使用した冗長構成になりますが、Multi-AZ構成でない場合や検証の場合等には、SINGLE_PIPELINEを使った方が安価に使えます。

スクリーンショット 2019-12-05 21.42.25.png

Input Attachments

ADDを押して、プルダウンからChannelに紐づけるinputを選択し、Confirmを押します。

スクリーンショット 2019-12-05 21.54.53.png

今回のケースだと、予告動画と終了後動画はループ再生させたいので、作成したInput Attachmentsを選択してSource End BehaviorLOOPに変更します。

スクリーンショット 2019-12-05 22.53.56.png

Output groups

作成したMediaStoreのコンテナを、配信先に設定します。

URL

ここのURLには、MediaStoreのコンテナに記載されているData endpointを記載しますが、httpsをmediastoresslに置き換える必要があるので、ご注意ください。

配信先にしたいMediaStoreのEndpointが下記のような場合、

https://XXXXXXXXXXXXXX.data.mediastore.ap-northeast-1.amazonaws.com/<path>/<basename>

URLには以下のように設定します。

mediastoressl://XXXXXXXXXXXXXX.data.mediastore.ap-northeast-1.amazonaws.com/<path>/<basename>

<path>にはコンテナ以下のパス、<basename>には設定したいマニフェストファイル名を入れます。
(OutputにName Modifierを設定した場合は、<basename>にName Modifierを結合した名前がマニフェストファイル名になります)

CDN Settings

今回はMediaStoreを配信先に指定しているので、Hls media storeを設定してください。

output.png

出力される映像の画角やビットレート、コーデック等についてはOutputごとに設定できるので、その辺りを調整する場合はそちらで行ってください。

Create Channel

ここまで設定が終わったら、Create channelを押します。

Schedule設定

最後に、配信スケジュールを作成します。

ChannelのScheduleタブを開き、Createします。

スクリーンショット 2019-12-05 23.26.25.png

2019/12/8 22:00になったら本編に切り替える

Action nameに適当な名前を入力します。
Start typeをFixedに指定し、Date、Timeを2019/12/8 13:00に設定します。(TimeはUTCなので注意)
次に、Action typeをInput Switchに、Input attachmentで本編であるmainを設定し、Createします。

スクリーンショット 2019-12-05 23.35.33.png

これで、2019/12/8 22:00(JST)になったら本編に切り替わるようになります。

本編が終了したら終了後動画に切り替える

Action nameに適当な名前を入力後、こちらではStart typeをFollowに指定します。
Reference action nameに上記で作成したスケジュール名を指定し、Follow pointをENDに設定します。
Action typeはinput Switchで、Input attachmentはfinishedを設定し、Createします。

スクリーンショット 2019-12-05 23.36.00.png

この設定で、本編が終了したら終了後動画に切り替わるようになります。

設定完了

上記の設定ができたら、Scheduleタブにはこのように表示されます。

スクリーンショット 2019-12-05 23.36.25.png

【注意】ChannelがRUNNINGじゃないとスケジュール機能は動作しない

若干ハマったポイントなんですが、スケジュール機能はChannelがRUNNING状態になっていないと動作しません。

設定したスケジュール日時になる前に必ずRUNNINGにしておきましょう。
(Scheduleを設定したから時間通り動くでしょとか思っていたら動きませんでした)

本当はChannelの起動もMediaLive内でできたらいいなとか思っているのですが、そのような機能はなさそう。
そこも自動化したければ、Lambda等と連携する必要がありそうです。

おわりに

これで全ての設定が完了です。お疲れ様でした。
ChannelをStartさせれば予告動画が配信され、スケジュール設定した時刻になれば本編が流れます。

今回はMediaLiveを使ってスケジュールした時間に予告→本編→終了後と切り替わる配信を試してみました。
ちょっとChannelの設定を作るのは大変ですが、これだけでスケジュール管理された動画配信ができるのはすごいですよね。

とはいえ、この操作を毎度コンソールから行うのは手間がかかり過ぎてしまうので、現実的にはSDKを使って自動で設定が作られるようにすべきだろうなとは思います。

参考記事

https://qiita.com/khagi/items/ff8120c498a7d45338b1
https://dev.classmethod.jp/cloud/aws/aws-elemental-medialive-programming-using-mp4-input-and-switch-input/
https://qiita.com/ryotax/items/60f7ec699cfaec62a8be

19
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
19
6