1. 背景の紹介
Nginx (エンジン x) は、高性能 HTTP およびリバース プロキシ サーバーです。 Nginx は、軽量の Web サーバー/リバース プロキシ サーバーおよび電子メール プロキシ サーバーです。その特徴は、メモリ占有量が少なく、強力な同時実行機能を備えていることです。実際、nginx の同時実行機能は、同じ種類の Web サーバー間でより優れたパフォーマンスを発揮します。中国本土の nginx Web サイトのユーザーには、Baidu、JD.com、Sina、NetEase、テンセント、タオバオなど
2. ナレッジ分析
1. プロキシ サーバー
一般に、プロキシ サーバーを介してインターネット上のサーバーにリクエストを送信する LAN 内のマシンを指します。通常、クライアント側で動作します。完全なプロキシ要求プロセスは次のとおりです。クライアントは最初にプロキシ サーバーとの接続を作成し、次に、プロキシ サーバーで使用されるプロキシ プロトコルに従って、ターゲット サーバーへの接続の作成またはターゲット サーバーの指定されたリソースの取得を要求します。 Web プロキシ (プロキシ) サーバーは、ネットワークの中間エンティティです。プロキシは Web クライアントと Web サーバーの間に配置され、「仲介者」の役割を果たします。 HTTP プロキシ サーバーは、Web サーバーでもあり、Web クライアントでもあります。
2. フォワード プロキシ
フォワード プロキシは、クライアントとオリジン サーバーの間のサーバーです。オリジン サーバーからコンテンツを取得するために、クライアントはリクエストを送信し、ターゲット (オリジン サーバー)、プロキシはリクエストをオリジン サーバーに転送し、取得したコンテンツをクライアントに返します。フォワード プロキシを使用するには、クライアントで特別な設定を行う必要があります。
3. リバース プロキシ
リバース プロキシ コンピュータの世界では、単一のサーバーでクライアント (ユーザー) のリクエストを処理できる能力には限界があり、ユーザーのアクセス リクエストが殺到すると、複数のサーバーを使用して何千ものユーザー リクエストを共有できます。これらのサーバーは同じサービスを提供するため、ユーザーはまったく違いを感じません。サーバーはクライアントのリクエストを受け入れ、そのリクエストを特定のサーバーに配布して処理し、サーバーの応答をクライアントにフィードバックします。
4. リバース プロキシの実装
1) ユーザー リクエストを分散し、ユーザー リクエストをアイドル状態のサーバーに分散するには、負荷分散デバイスが必要です;
2) サーバーは、そのリクエストを返します。独自のサービスを負荷分散デバイスに送信します;
3) 負荷分散はサーバーのサービスをユーザーに返します;
3. よくある質問
1. フォワード プロキシとリバースプロキシ リバース プロキシの違いは何ですか
2. リバース プロキシを使用する理由
4. 解決策
答え: 1. 2 つの違いは、オブジェクトのオブジェクトが異なることです。プロキシは異なります。プロキシによって表されるオブジェクトはクライアントであり、リバース プロキシによって表されるオブジェクトはサーバーです。
回答: 2. サーバーの分散と拡張を促進します。実際には、単一のサーバーでクライアント リクエストを処理できる能力には限界があります。リクエストの数が多すぎると、サーバーはビジー状態になります。そのため、複数のサーバーを使用してユーザーのリクエスト処理を共有します。これらのサーバー同じサービスを提供するので、ユーザーにとっては違いはありません。次に、ユーザーのリクエストをアイドル状態のサーバーに分散するために負荷分散デバイスが必要になります。その後、サーバーは結果を負荷分散デバイスに返し、負荷分散はその結果をユーザーに返します。この方法では、サーバーを追加/削除するときに、サーバーのセキュリティに影響を与えることなく、負荷分散サーバーのリストを変更するだけで済みます。 IP アドレスとポートがインターネットに直接公開されることを回避し、ホストがセキュリティの脆弱性を悪用されるのを防ぎ、プロキシ サーバーの数が制限されているため、セキュリティ保護がより便利になります。
5. 参考文献
Baidu、書籍
6. その他のディスカッション
1. 負荷分散アルゴリズムとは何ですか?
回答: ラウンド ロビン方式、ランダム (Random) 方式、ソース アドレス ハッシュ (Hash) 方式、加重ラウンド ロビン (Weight Round Robin) 方式、加重ランダム (Weight Random) 方式、最小接続数方式。
2. 設定内のサーバー名は何を意味しますか?
回答:
Nginx のserver_name ディレクティブは、主に名前ベースの仮想ホストを構成するために使用されます。リクエストを受信した後のserver_name ディレクティブの一致順序は次のとおりです:
1 、server_name は
2 に完全に一致し、* ワイルドカード文字
3 で始まる文字列、* ワイルドカード文字
4 で終わる文字列、一致する正規表現:
3. リバース プロキシとロード バランシングの違いは何ですか?
回答: リバース プロキシは、負荷分散を実現する方法です。まずリバース プロキシについて説明しましょう。ユーザーがリクエストを行うと、まずプロキシ サーバーにリクエストを送信し、次にプロキシ サーバーがアルゴリズムに従って実サーバーにリクエストを送信し、最後にリクエストをユーザーに返します。このアプローチでは、第一にセキュリティが向上し、第二に、複数の実サーバーを通じてユーザー要求を共有し、負荷分散を実現します。負荷分散についてもう一度話しましょう。負荷分散の登場は、水平方向の拡張によって単一サーバーの負荷を可能な限り軽減することです。一般的な WEB レベルの負荷分散ソリューションには、ハードウェア F5、Nginx プロキシ、LVS、さまざまなクラウド プロバイダーの負荷分散サービス (AWS ELB サービスなど) などが含まれます。負荷分散の背後に接続されるのは通常、実際にサービスを提供するサーバーであり、たとえば ELB サービスを通じてトラフィックを均等に共有できるため、スタンドアロン サーバーの負荷が軽減されます。
Nginx 関連の技術記事の詳細については、Nginx チュートリアル 列にアクセスして学習してください。
以上がnginxリバースプロキシとはどういう意味ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。