HTTPのステータスコード499とnginxの499エラーの比較説明
ログ レコードの HTTP ステータス コードに 499 エラーが表示される状況は数多くあります。私が遭遇した状況の 1 つは、nginx がバックエンドに戻され、ログ ステータス レコードが 499 であったということです。送信バイト数は0です。
オンライン製品は長い間変更されていないため、ウェブサイトのシステムが調子が悪いと報告するユーザーが常にいます。そのため、フロントエンドプログラムの問題は基本的に除外できます。そのため、インターフェイスが問題であると考えましたGetメソッドで呼び出されるメッセージが不安定なので問い合わせたところ、問題ないとのことでしたので、確実な証拠を得るためにnginxサーバーのログファイル(awstatsログ)を解析したところ、問題ありませんでした。ログにはエラー コード 499 のエラーが多数あり、ログ ファイル全体の約 1% を占め、すべてのエラー レポートの約 70% しか占めていないことがわかります (すべてのエラー レポートについては、次の図を参照してください)。すべてのエラー レポートの合計は 1% を超えますが、これは依然として非常に大きな量です。
499エラーとは何ですか? NGINX のソース コードの定義を見てみましょう:
ngx_string(ngx_http_error_495_page), /* 495, https 証明書エラー */
ngx_string(ngx_http_error_496_page), /* 496, https 証明書がありません */
ngx_string( ngx_http_error_497_page), / * 497, http から https */
ngx_string (ngx_http_error_404_page),/ * 498, キャンセルされました */
Ngx_null_String,/ * 499, クライアントが接続を閉じました */
499 は、「クライアントが接続を閉じました」に対応します」。これは、サーバー側の処理時間が長すぎてクライアントが「せっかち」であることが最も考えられます。
Nginx 499 エラーの原因と解決策
Nginx の access.log を開くと、最後の送信に HTTP1.1 499 0 が表示されていることがわかります。Baidu で nginx 499 エラーを検索すると、結果はすべて「クライアントがアクティブに切断されました」と表示されます。
しかし、テストした結果、これは明らかにクライアントの問題ではありません。ポート + IP を使用してバックエンド サーバーに直接アクセスすると、この問題が発生しないからです。後で nginx をテストしたときに、投稿が 2 回送信された場合に発生することがわかりました。あまりにも早く、499 が表示されます。nginx が安全でない接続であると判断し、クライアントの接続を積極的に拒否したようです
しかし、関連する問題を検索しても解決策が見つかりませんでした。このエラーの解決策は英語のフォーラムにあります:
proxy_ignore_client_abort on;
これが安全かどうかはわかりません。
これは、パラメータ proxy_ignore_client_abort on; を設定することを意味します。
プロキシ サーバーがアクティブにクライアント接続。
この設定で nginx を再起動すると、問題は実際に解決されます。セキュリティが少し欠けていますが、常にサーバーが見つからないよりははるかに良いです。
もう 1 つの理由は、後でテストしたところ、クライアントが実際に接続を閉じているか、接続がタイムアウトになっていることがわかり、どれだけタイムアウトを設定しても、PHP プロセスが不十分であることが判明しました。 PHPのプロセス数の問題を改善し、デフォルトで子プロセスが5つしか開かない問題を解決しました。
以上がHTTPのステータスコード499とnginxの499エラーの比較説明の詳細内容です。詳細については、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)

ホットトピック









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にアクセスして、デフォルトのウェルカムページを表示します。

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

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にアクセスできます

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

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

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

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