ホームページ > バックエンド開発 > PHPチュートリアル > 複数の Docker コンテナ間で Web サービスの負荷を分散するために Nginx プロキシ サーバーを構成するにはどうすればよいですか?

複数の Docker コンテナ間で Web サービスの負荷を分散するために Nginx プロキシ サーバーを構成するにはどうすればよいですか?

WBOY
リリース: 2023-09-05 12:02:01
オリジナル
1643 人が閲覧しました

複数の Docker コンテナ間で Web サービスの負荷を分散するために Nginx プロキシ サーバーを構成するにはどうすればよいですか?

複数の Docker コンテナ間で Web サービスの負荷分散を実現するために Nginx プロキシ サーバーを構成するにはどうすればよいですか?

はじめに:
クラウド コンピューティングとコンテナ化テクノロジの急速な発展に伴い、Web サービスにおける負荷分散の重要性がますます高まっています。 Nginx は、高性能 Web サーバーおよびリバース プロキシ サーバーとして、負荷分散を実現するためにますます多くの人に使用されています。この記事では、複数の Docker コンテナ間で Web サービスの負荷分散を実現するために Nginx プロキシ サーバーを構成する方法を紹介し、対応するコード例を添付します。

1. Docker 環境のインストール

まず、ホストに Docker 環境をインストールする必要があります。具体的なインストール手順については、Docker 公式ドキュメントを参照してください。

2. Dockerfile を作成する

次に、Web サービス用の Dockerfile を作成する必要があります。 Dockerfile は、Docker イメージを自動的に構築するために使用されるテキスト ファイルです。このファイルでは、基本イメージを指定し、必要な依存関係をインストールし、ソース コードをコピーする必要があります。

以下はサンプル Dockerfile です:

FROM nginx

COPY nginx.conf /etc/nginx/nginx.conf
COPY default.conf /etc/nginx/conf.d/default.conf
COPY html /usr/share/nginx/html

EXPOSE 80

CMD ["nginx", "-g", "daemon off;"]
ログイン後にコピー

この例では、Nginx によって公式に提供されているベース イメージを使用します。次に、カスタマイズした nginx.conf、default.conf、および html フォルダーをコンテナ内の対応する場所にコピーします。最後に、コンテナのポート 80 を公開し、CMD コマンドを使用して Nginx サービスを開始します。

3. Nginx プロキシ サーバーの構成

ホストに Docker 環境をインストールし、Dockerfile を作成した後、Nginx プロキシ サーバーの構成を開始できます。

  1. 次の内容を含む新しい Nginx 構成ファイル nginx.conf を作成します。
worker_processes  1;

events {
    worker_connections  1024;
}

http {
    upstream backend {
        server backend1:80;
        server backend2:80;
    }

    server {
        listen 80;

        location / {
            proxy_pass http://backend;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    }
}
ログイン後にコピー

この構成ファイルでは、アドレスとアドレスが含まれるアップストリームという名前のバックエンドを定義します。すべてのバックエンド コンテナのポート。次に、ポート 80 でリッスンするサーバー ブロックを作成し、その中にリバース プロキシ ロケーション ブロックを定義しました。このロケーション ブロックでは、proxy_pass ディレクティブを使用してリクエストを上流のバックエンドに転送し、proxy_set_header ディレクティブを設定してリクエスト ヘッダー情報を渡します。

  1. 構成ファイル nginx.conf を Dockerfile と同じディレクトリにコピーし、Docker イメージをビルドします。
docker build -t my-nginx .
ログイン後にコピー
  1. 複数のコンテナーを実行する

Nginx プロキシ サーバーを構成する前に、複数のコンテナをバックエンド サービスとして実行する必要があります。次のコマンドを使用して 2 つのコンテナーを実行できます:

docker run -d --name backend1 my-nginx
docker run -d --name backend2 my-nginx
ログイン後にコピー

この方法で、2 つのコンテナーで Nginx サービスを実行します。

  1. Nginx プロキシ サーバーの実行

最後に、構成された Nginx プロキシ サーバーを実行し、バックエンド コンテナに接続するための新しいコンテナを作成する必要があります。次のコマンドを使用して Nginx プロキシ サーバーを実行できます:

docker run -d -p 80:80 --link backend1 --link backend2 my-nginx
ログイン後にコピー

この方法では、ホスト ポート 80 からのすべてのリクエストが Nginx プロキシ サーバーによって受信され、次のコマンドに従ってバックエンドの 2 つのコンテナに分散されます。負荷分散アルゴリズム。

概要:
複数の Docker コンテナ間で Web サービスの負荷分散を実現するように Nginx プロキシ サーバーを構成することで、リソースをより有効に活用し、アプリケーションのパフォーマンスと安定性を向上させることができます。この記事では、Docker 環境のインストールから Nginx プロキシ サーバーの構成までの詳細な手順を紹介し、対応するコード例を示します。この記事が Nginx プロキシ サーバーの理解と使用に役立つことを願っています。

以上が複数の Docker コンテナ間で Web サービスの負荷を分散するために Nginx プロキシ サーバーを構成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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