ホームページ > 運用・保守 > Linuxの運用と保守 > nginx と nginx-rtmp-module を使用してストリーミング メディア サーバーを構築する

nginx と nginx-rtmp-module を使用してストリーミング メディア サーバーを構築する

零下一度
リリース: 2017-06-29 11:11:43
オリジナル
2477 人が閲覧しました

nginx と nginx-rtmp-module を使用してストリーミング メディア サーバーを構築するときに、非常に厄介な問題に遭遇しました。nginx-rtmp-module モジュールを nginx に追加するとき、私が最初にとったアプローチは、元の nginx をアンインストールしてから、 nginx と nginx-rtmp-module のソース コードを再コンパイルしてインストールしました。再インストール後、ストリーミング メディア サーバーをテストしたところ正常でしたが、以前に構築した LUMP 環境にいくつかの WEB プロジェクトがデプロイされていたために問題が発生しました。 nginx が再インストールされたので、これらのプロジェクトを再デプロイする必要があります。そこで、これらの WEB プロジェクトを再デプロイし始めましたが、結果は、nginx のディレクトリ構造が変更されていたため、泣いてトイレで気を失いました。 , その後、元の WEB プロジェクトを設定することができず、インターネットで多くの解決策を探しましたが、そのほとんどは nginx のコンパイルとインストール、プッシュとプルの方法に焦点を当てていました。この点に関しては、フロー テストには私の問題は関係ありませんでした。後で投稿を閲覧しているときに、元の nginx 共有ライブラリを自分でコンパイルした nginx 実行可能ファイルに置き換えると問題が解決する可能性があると言っているのを見つけたので、すぐに実行しました。これで、nginx はストリーミング メディア サービスを実行し、同時に WEB プロジェクトをデプロイできるようになりました

以下は、私の操作プロセスを簡単に紹介します。 , 同じ問題に遭遇したあなたにいくつかの洞察をもたらすことを願っています。この方法でインストールされた nginx の現在のバージョン番号は 1.10 です

1 sudo apt-get update2 sudo apt-get install nginx
ログイン後にコピー
2. 好きなディレクトリに移動し、nginx と nginx-rtmp-module のソース コードを保存するための好きな名前のディレクトリを作成します。私はルートディレクトリ/softwaresにいます(ソフトウェアも自分のものです。 以下にnginxディレクトリが作成されます。 次に、nginxとnginx-rtmp-moduleをnginxディレクトリにダウンロードします。

1 cd softwares/2 sudo mkdir nginx
ログイン後にコピー
3.nginxディレクトリに入ります。

1 cd nginx/
ログイン後にコピー
4. nginx ソース コードをダウンロードします。ご注意ください: 不要な問題を避けるために、ダウンロードされたソース コードのバージョンは、手順 1 でインストールされた nginx のバージョンと一致している必要があります。nginx ソース コードを入手するには、さまざまな方法があります。推奨される方法は 2 つあります

方法 a: ターミナルの nginx コマンドで apt-get source を実行し、対応するバージョンのソース コードを直接取得します

1 sudo apt-get source nginx
ログイン後にコピー
この方法は、ダウンロード後に自動的に解凍され、nginx-1.10 になります。 .0 ディレクトリは nginx のソース コード ディレクトリです。

方法 b: nginx の公式 Web サイトで対応するバージョンを見つけてダウンロードします。

1 sudo wget nginx.org/download/nginx-1.10.0.tar.gz
ログイン後にコピー
この方法でダウンロードした後、デコード コマンドを手動で解凍する必要があります。 :

1 sudo tar zxvf nginx-1.10.0.tar.gz
ログイン後にコピー
5. nginx-rtmp-moduleのソースコードをダウンロードします

1 sudo wget github.com/arut/nginx-rtmp-module/archive/master.zip
ログイン後にコピー
nginx-rtmp-moduleはすでにGitHub上にあるので オープンソースなのでGitHubから直接入手することもできます。アドレス:

6. nginx-rtmp-module ソースコードの圧縮パッケージを解凍します。

1 sudo unzip master.zip
ログイン後にコピー
7. nginx ソースコードディレクトリに入ります。

1 cd nginx-1.10.0/
ログイン後にコピー
8. 現在の nginx 設定情報を表示し、現在の nginx 設定情報を保存します後で nginx ソース コードをコンパイルするときに、現在の設定情報に基づいて設定する必要があります。コマンド ラインの V は大文字または小文字であることに注意してください。nginx のバージョン番号のみです。現在の nginx 構成情報は次のとおりです:

1 nginx -V
ログイン後にコピー
9. nginx ソース コードのコンパイル情報を構成し、nginx-rtmp-module を nginx に追加します。このコマンドは実際に構成されていることに注意してください。次のように: sudo ./configure --add-module=../nginx-rtmp-module-master これにより、nginx-rtmp-module が nginx 設定に追加されます。以前に保存した nginx 設定情報が、このコンパイルに使用される設定情報に追加され、コンパイルされた nginx が元の nginx と可能な限り同じ機能を持つようになります。注意深い学生は、私が実際に nginx 情報を設定していることに気づくでしょう。元の設定情報をすべてコピーして貼り付けると、コンパイル中に処理するのが難しいエラーが発生するため、元の設定情報をすべて書き込むことはできません。しばらくの間、これらのエラーに対する適切な解決策が見つからないため、いくつかの設定を行います。情報が削減されていますので、機能モジュールに大きな違いはありませんので、安心してご利用いただけます。

10. 設定が完了したら、make コマンドを実行して nginx のソースコードのコンパイルを開始します。コンパイルが完了すると、nginx ソース コード ディレクトリに配置されます。objs ディレクトリに nginx 実行可能ファイルを生成します。

--with-cc-opt='-g -O2 -fPIE -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2' --with-ld-opt='-Wl,-Bsymbolic-functions -fPIE -pie -Wl,-z,relro -Wl,-z,now' --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_addition_module --with-http_dav_module --with-http_geoip_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module --with-http_v2_module --with-http_sub_module --with-http_xslt_module --with-stream --with-stream_ssl_module --with-mail --with-mail_ssl_module --with-threads
ログイン後にコピー

11. 生成された nginx 実行可能ファイルを /usr/sbin ディレクトリにコピーし、元の nginx 共有ファイルを置き換えます。注: 元の /usr/sbin ディレクトリには nginx 共有ライブラリ ファイルがあり、コンパイルされた nginx 実行ファイルを使用して置き換えます。

1 sudo ./configure --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_addition_module --with-http_dav_module --with-http_geoip_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_v2_module --with-http_sub_module --with-http_xslt_module --with-stream --with-stream_ssl_module --with-mail --with-mail_ssl_module --with-threads --add-module=../nginx-rtmp-module-master
ログイン後にコピー

12. nginx を再起動します。

1 sudo make
ログイン後にコピー
13. nginx を確認します。設定情報をもう一度確認します。

1 sudo nginx /usr/sbin
ログイン後にコピー
nginx-rtmp-module モジュールが nginx に追加されたことがわかります。

1 sudo service nginx restart
ログイン後にコピー

ストリームをプッシュおよびプルしてみたところ、機能は正常でした。元の WEB プロジェクトを再度実行したところ、これも正常でした。

最後に、最初に nginx をインストールする必要がある理由を説明します。その理由は、LUMP 環境での WEB プロジェクトのデプロイを容易にするためです。最初に apt-get を介して nginx をインストールせず、ソース コードを直接ダウンロードしてコンパイルし、nginx 設定をインストールする必要があります。ディレクトリが不完全になり、WEB プロジェクトをデプロイするのが難しくなります (おそらく、一部の操作を介してデプロイすることもできますが、特定の操作にはまだ nginx を検討する時間が必要です) ストリーミング メディア サービスを設定していない場合は、これをお勧めします。 apt-get による nginx のインストール 手順は簡単で安心です

以上がnginx と nginx-rtmp-module を使用してストリーミング メディア サーバーを構築するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート