nginxプロキシsocket.ioサービスの落とし穴を解決する方法
nginx は 2 つのsocket.io サーバーのプロキシとして機能します。 socket.io の動作モードは、ポーリングと websocket へのアップグレードです
現象
nginx 経由でサービスをリクエストすると、大量の 400 エラーが表示されます。 WebSocket にアップグレードされました。時々、エラーが報告され続けることがあります。ただし、ip ポート
経由で直接アクセスすると、100% 成功します。
分析
sid
sid が問題の鍵です。最初に接続を作成するとき (ポーリング モードは長い接続をシミュレートします)、クライアントは次のようなリクエストを開始します:
https://***/?eio=3&transport=polling&t=1540820717277-0
それを受信した後、サーバーはオブジェクトを作成し、それを接続にバインドし、セッションをマークするための sid (セッション ID) を返します。セッションとは何を指しますか? セッションは一連のインタラクションであり、これらのインタラクションは関連しています。私たちのシナリオでは、次の http リクエストが来たときに、以前に理論にバインドされていた長い接続を見つける必要があります (ここではまだ説明されていません) ) websocket なので理論上)。 http リクエストはステートレスであり、各リクエストは独立していることがわかっているため、socket.io はこれを行うために sid を導入しました。サーバーはリクエストを受信した後に SID を生成します。レスポンスを見てください:
コードをコピーします。コードは次のとおりです:
{"sid":"eogal3frqlptoalp5est","upgrades":[ "websocket"] ,"pinginterval":8000,"pingtimeout":10000}
後続のすべてのリクエストではこの SID が必要であり、WebSocket リクエストを確立するための接続も例外ではありません。したがって、sid はポーリングとポーリングを WebSocket にアップグレードするための鍵となります。この後のリクエストは次のようになります:
https://***/?eio=3&transport=polling&t=1540820717314-1&sid=eogal3frqlptoalp5est or wss://***/?eio=3&transport=websocket&t=1540820717314-1&sid=eogal3frqlptoalp5est
次に質問は、リクエスト内の sid がサーバーによって生成されなかった場合はどうなるかということです。サーバーはそれを認識せず、400 を返し、
invalid sid
これが私たちが遭遇した問題です。nginx のデフォルトの負荷分散戦略はポーリングであるため、リクエストは生成されない可能性があります。この SID を持つマシンに移動すると、この時点で 400 を受信します。運が良ければ、元のマシンに送信される可能性があります。運が良ければ、WebSocket 接続が確立されるまで持続することもできます。
ソリューション
ここでは 2 つのソリューションを提案します
nginx の負荷分散は、クライアントのリクエストを保証できる ip_hash を使用します。 1 つのサーバーに接続する
ポーリング モードを使用せず、WebSocket のみを使用します
どちらのオプションにもそれぞれ長所と短所があります。 2 番目の明らかな点は、WebSocket をサポートしていない古いブラウザとクライアントは動作しないことです。最初のタイプの問題は、さらに奥深くに隠されています。マシンを追加または削除すると何が起こるかを想像してみてください。このとき、ip_hash ポリシーのモードが変更され、以前のすべての接続が無効になります。マイクロサービスの場合、拡張と縮小は非常に重要です。操作が頻繁に行われる場合 (特に製品が開発段階にある場合)、この種の損失を伴う拡張や縮小はおそらく許容できません。
以上がnginxプロキシsocket.ioサービスの落とし穴を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Linuxでは、次のコマンドを使用して、nginxが起動されるかどうかを確認します。SystemCTLステータスNGINXコマンド出力に基づいて、「アクティブ:アクティブ(実行)」が表示された場合、NGINXが開始されます。 「アクティブ:非アクティブ(dead)」が表示されると、nginxが停止します。

Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

Linuxでnginxを開始する手順:nginxがインストールされているかどうかを確認します。 systemctlを使用して、nginxを開始してnginxサービスを開始します。 SystemCTLを使用して、NGINXがシステムスタートアップでNGINXの自動起動を有効にすることができます。 SystemCTLステータスNGINXを使用して、スタートアップが成功していることを確認します。 Webブラウザのhttp:// localhostにアクセスして、デフォルトのウェルカムページを表示します。

Nginx 403禁止エラーを修正する方法は?ファイルまたはディレクトリの許可を確認します。 2。HTACCESSファイルを確認します。 3. nginx構成ファイルを確認します。 4。nginxを再起動します。他の考えられる原因には、ファイアウォールルール、Selinux設定、またはアプリケーションの問題が含まれます。

質問への回答:304変更されていないエラーは、ブラウザがクライアントリクエストの最新リソースバージョンをキャッシュしたことを示しています。解決策:1。ブラウザのキャッシュをクリアします。 2.ブラウザキャッシュを無効にします。 3.クライアントキャッシュを許可するようにnginxを構成します。 4.ファイル許可を確認します。 5.ファイルハッシュを確認します。 6. CDNまたは逆プロキシキャッシュを無効にします。 7。nginxを再起動します。

NGINXサーバーを起動するには、異なるオペレーティングシステムに従って異なる手順が必要です。Linux/UNIXシステム:NGINXパッケージをインストールします(たとえば、APT-GetまたはYumを使用)。 SystemCtlを使用して、NGINXサービスを開始します(たとえば、Sudo SystemCtl Start NGinx)。 Windowsシステム:Windowsバイナリファイルをダウンロードしてインストールします。 nginx.exe実行可能ファイルを使用してnginxを開始します(たとえば、nginx.exe -c conf \ nginx.conf)。どのオペレーティングシステムを使用しても、サーバーIPにアクセスできます

サーバーには、要求されたリソースにアクセスする許可がなく、NGINX 403エラーが発生します。ソリューションには以下が含まれます。ファイル許可を確認します。 .htaccess構成を確認してください。 nginx構成を確認してください。 SELINUXアクセス許可を構成します。ファイアウォールルールを確認してください。ブラウザの問題、サーバーの障害、その他の可能なエラーなど、他の原因をトラブルシューティングします。
