Nginx ポート競合を解決するトラブルシューティング方法の例

Nginx ポート競合を解決するトラブルシューティング方法の例

問題の説明

データ転送に Nginx を使用し、フロントエンドとバックエンドが分離された Spring + Angular プロジェクト。

Nginx はポート 8100、フロントエンド ポート 4200、バックエンド ポート 8080 をリッスンします。

いつものように、事前に MySQL と Redis を設定し、プロジェクトの Nginx 設定ファイルをインポートしてから、フロントエンドとバックエンドを正常に起動します。

その後、問題が発生しました。フロントエンドによって開始されたリクエストのうち、バックエンドで受信できるのはごく少数で、そのほとんどが 404 でした。ブラウザをクリックすると、コンソールに 404 が表示され続けました。

404 だけの場合、問題は非常に単純で、Nginx ポート転送設定が間違っている可能性が非常に高くなります。しかし、魔法のようなのは、バックグラウンドに到達できるリクエストがまだいくつかあるということです。

(上の画像では、保存が成功すると、背景に関連するコンソール情報が出力されます)

他の友達はこの問題を抱えていなかったので、私は調査を始めました。

トラブルシューティングのプロセス

バックエンドの問題なのか、 Nginx転送の問題なのかを判断するには、まずブラウザのネットワークから、404 がバックエンドから返されたのか、Nginx から返されたのかを確認する必要があります。

確認してみると、Nginx によって返されたことがわかりました。バックグラウンドが 404 を返す場合、エラー情報が HTTP リクエスト ヘッダーに書き込まれます。

まず、リスニング ポートに競合がないか確認します。nginx -T を使用して、インポートされた外部ファイルを含む完全な Nginx 構成ファイルを表示します。

// 設定ファイルが正しいかどうかをテストし、完全な設定ファイルを出力します nginx -T 

出力結果には 8100 のみが表示されており、複数のプロジェクトが導入されているにもかかわらず、リスニング ポートの競合がないことがわかります。

次に、Nginx ログからいくつかの手がかりを探す予定です。

Nginx のログ モードをオンにした後、ログ ファイルを確認すると、数千件のアクセス レコードが見つかりました。

大部分は 404 で、いくつかは 200 ですが、ログにはそれほど役立つ情報は提供されません。

最終的に、構成ファイルに問題が見つかりました。

HomeBrew を使用してインストールされた Nginx の場合、グローバル構成ファイルのデフォルトのリスニング ポートは 8080 であり、プロジェクト バックエンドが占有するポートも 8080 です。

ポート監視とポート占有の原理についてはよく分かりませんが、少なくとも、Nginx はポート 8080 を監視するため、一部のリクエストは Nginx 自体に送信され、他の部分はバックグラウンドに送信されることは分かっています。

したがって、グローバル構成ファイルを変更し、デフォルトのポートを変更すると、問題は解決します。

// 設定ファイルを変更する sudo vim /usr/local/etc/nginx/nginx.conf
// テスト設定ファイル nginx -t
// Nginxを再起動
nginx -s リロード

最後に、すべてのリクエストがバックエンドに到達できるようになります。

要約する

XAMPP を学び始めた頃、「ポート 80 で競合がある場合は、ポートを変更してください。たとえば、8080 に変更してください」とよく聞きました。

しかし、8080 が習慣になると、いくつかのプロジェクトでもこのポートが使用されるようになるため、競合の問題を解決する必要があります。

将来的にデフォルト ポートを変更する場合は、プロジェクトのポートとの競合を避けるために、10000 を超えるポート番号など、使用される可能性が低いポートに変更することをお勧めします。

Nginx ポート競合を解決するためのトラブルシューティング方法の例については、これで終わりです。Nginx ポート競合のトラブルシューティング方法についての詳細は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • nginxとバックエンドポート間の競合の解決策

<<:  ネイティブ js カスタム右クリック メニュー

>>:  mysqlはストアドプロシージャを使用してツリーノード取得メソッドを実装します。

推薦する

Debian 9 システムに MySQL データベースをインストールする方法

序文タイトルを見ると、誰もが「Debian 9 に MySQL をインストールするにはどうすればいい...

Nginx/Httpd リバース プロキシ Tomcat 設定チュートリアル

以前のブログでは、Tomcatのサーバーの各コンポーネントの使用について学びました。 Tomcatは...

MySQL でスロークエリを有効にする方法の例

序文スロー クエリ ログは、MySQL で非常に重要な機能です。MySQL のスロー クエリ ログ機...

ズームインとズームアウトの閉じるボタンを実現する CSS (サンプル コード)

この効果はブラウザ ページで最もよく見られます。まずは効果の画像をご覧ください。 上の図に示すように...

Navicat が MySQL にリモート接続するときに発生する 10060 不明エラーを解決する方法

はじめに:今日は、サーバー上のMySQLにリモート接続したいと思います。使用するソフトウェアはNav...

Ubuntu 20.04 に GitLab をインストールして設定する方法

導入GitLab CE または Community Edition は、主に Git リポジトリのホ...

JavaScript を使用してハイパーリンクのリダイレクトを防ぐ方法 (複数の書き方)

JavaScript を使用すると、ハイパーリンクがジャンプするのを防ぐことができます。方法は次の...

Kylin 4.0.2 (Ubuntu) でブート パーティションを拡張するプロセスの紹介

目次序文1. 新しいパーティションを準備する2. ブートパーティションをコピーする3. fstabフ...

MySQL データベースの最適化: テーブルとデータベースのシャーディング操作の詳細な説明

この記事では、例を使用して、MySQL データベースの最適化のためのテーブルおよびデータベース シャ...

ホワイトボードを踏まないようにするゲームを実装するための HTML+CSS+JS

目次背景1. 思考分析2. ページ構成2.1 HTML レイヤー2.2 CSS レイヤー2.3 JS...

サイト全体を灰色にするCSSコードのまとめ

国務院は本日、新型コロナウイルス感染症との闘いで殉教した方々と犠牲者に対し、全国各民族人民の深い哀悼...

HTML で 2 つの div タグの間に垂直線を描く方法

最近、インターフェースを描画しているときに、インターフェースに垂直線を描画し、この垂直線の高さが親 ...

mysql5.7 以降で my.ini を設定するための詳細な手順

Windows 64 ビット版 MySQL 5.7 以降の解凍パッケージにデータディレクトリ、my-...

MySQL の自動インクリメント主キーが連続していないのはなぜですか?

目次1. はじめに2. 自己増分ストレージの説明3つの自己付加価値修正メカニズム4. 自己評価を修正...

MySQL テーブルデータのインポートとエクスポートの例

この記事では、MySQL テーブル データのインポートおよびエクスポート操作について説明します。ご参...