15
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

ストリーミングサーバーを10分で作る (ubuntu 24.04 + nginx)

Last updated at Posted at 2020-03-02

新型コロナウィルスへの警戒感で、カンファレンスが中止されたりして、配信を試してみたいとの要望が出てきたため10分でさくっと生配信のためのストリーミングサーバーを作る方法を解説します。

(追記 24/12/4)意外とリクエスト数が多いので、最新環境に書き換えます。

環境

  • Ubuntu 24.04LTS

今回はさくっと作るのでAmazon Lightsailを使いました。最低のインスタンスだと月額$5ですが、転送量1TBなので本格的に配信を考えると転送容量制限の緩い他VPSが良い気がします。

通常のUbuntu Server 24.04をインストールした環境でも良いかと思います。

インストール

update & upgradeで最新まで上げておきます。

sudo apt update
sudo apt upgrade

nginxのレポジトリーを追加します。Officalじゃないので確認されるが[Enter]で進みます。

sudo add-apt-repository ppa:nginx/stable

nginxとrtspモジュールを追加するだけです。

sudo apt install -y nginx libnginx-mod-rtmp

インストールはなんとこれで完了です。

設定

  • rtmpの設定をnginx.confの末尾に追加します。

sudo nano /etc/nginx/nginx.conf

/etc/nginx/nginx.conf
...
rtmp {
  server {
    listen 1935;
    chunk_size 4096;
    application live {
      live on;
      hls on;
      hls_path /var/www/html;
      hls_fragment 5s;
      hls_type live;
    }
  }
}
  • サービスリスタートします。

sudo service nginx restart

  • index.htmlにhtml5対応のビューワーのvideo-jsを追加します。

{ip}をサーバーIPに、{key}をストリームキーに置き換えてください。

sudo nano /var/www/html/index.html

/var/www/html/index.html
<!DOCTYPE html>
<html lang="en" class="">
<head>
  <link href="http://vjs.zencdn.net/7.6.6/video-js.css" rel="stylesheet">
  <script src="http://vjs.zencdn.net/7.6.6/video.js"></script>
</head>
<style type="text/css">
  #live {
    position: absolute;
    left: 0;
    top: 0;
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
</style>
<body>
  <video id="live" class="video-js vjs-default-skin" controls autoplay fullc preload="auto" data-setup='{}'>
    <source src="{key}.m3u8" type='application/x-mpegURL'>
    <source src="rtmp://{ip}:1935/live/{key}" type='rtmp/mp4'>
    <p class="vjs-no-js">Not Suppoted</p>
  </video>
</body>
</html>

ファイアウォール

サーバーのファイアウォール設定がある場合には1935を開放します

スクリーンショット 2020-03-02 20.08.36.png

配信設定

配信にはOBSなどを使うと良いでしょう。

配信情報は以下のように設定します。
{ip}をサーバーIPに、{key}をストリームキーに置き換えてください。

配信先: rtmp://{ip}:1935/live
スリームキー: {key}

スクリーンショット 2020-03-01 16.46.29.png

これで配信サーバー構築完了です。お疲れ様でした。

ぶつぶつ

30〜60秒程度の遅延があります(HLSなので遅い?)

安定性をとるならもちろんZoom Webinerとかを使う方が良い気がしますが、自分でサーバーを構築してしまうのも勉強になるかと思います。どのくらいまで耐えられるかは不明ですが、CPU負荷をみるとそこそこ耐えれる気がします。

構築用スクリプトを使う方法は使っているバージョンが古いのでアップデートしようと思ったところ、バイナリーパッケージが入手できる方法があったので公開する事にしました。

15
19
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
15
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?