ホームページ 運用・保守 Nginx nginx が高い同時実行性を実現する方法

nginx が高い同時実行性を実現する方法

Jun 04, 2019 pm 05:34 PM
nginx

簡単に言うと、これは非同期、ノンブロッキングで、epoll と多くの基盤となるコードの最適化を使用します。

もう少し詳しく言うと、nginxの特殊なプロセスモデルとイベントモデルの設計です。

nginx が高い同時実行性を実現する方法

ビデオ コースの推奨事項 →: 「数千万のデータに対する同時実行ソリューション (理論と実践)」

プロセス モデル

nginx はマスター プロセスと複数のワーカー プロセスを採用しています。

マスター プロセスは主にリクエストの収集と配布を担当します。リクエストが届くと、マスターはワーカー プロセスを開始してリクエストを処理します。

マスター プロセスは、高い信頼性を確保するためにワーカーのステータスを監視する役割もあります。

ワーカー プロセスは、通常、CPU コアの数に一致するように設定されます。 nginx のワーカー プロセスは Apache とは異なります。 Apche プロセスは同時に 1 つのリクエストしか処理できないため、多くのプロセス (数百、場合によっては数千) が開かれることになります。 nginx のワーカー プロセスが同時に処理できるリクエストの数はメ​​モリによってのみ制限されるため、複数のリクエストを処理できます。

イベント モデル

nginx は非同期でノンブロッキングです。

リクエストが受信されるたびに、それを処理するワーカー プロセスが存在します。しかし、それがプロセス全体ではありません。リクエストを上流 (バックエンド) サーバーに転送し、リクエストが返されるのを待つなど、ブロックが発生する可能性があるプロセス。そうすれば、処理作業者は愚かに待つことはなく、リクエストを送信した後、「上流が戻ったら教えてください。続行します」というイベントを登録します。それで彼は休みました。この時点で、別のリクエストが来た場合は、この方法ですぐに対応できます。上流サーバーが戻ると、このイベントがトリガーされ、ワー​​カーが引き継ぎ、リクエストはダウンし続けます。

Web サーバーの動作特性により、各リクエストの処理時間のほとんどがネットワーク送信に費やされることが決まり、実際、サーバー マシンに費やされる時間はそれほど多くありません。これが、わずか数プロセスで高い同時実行性を解決する秘訣です。

IO 多重化モデル epoll

epoll()、カーネルはリンク リストを維持し、epoll_wait はリンク リストが空かどうかを直接チェックして、ファイル記述子の準備ができているかどうかを確認します。 。カーネルは、各 sockfd 上のデバイス ドライバーで確立されたコールバック関数に基づいて epoll を実装します。その後、sockfd 上のイベントが発生すると、対応するコールバック関数が呼び出されて、この sockfd がリンク リストに追加されますが、他の「アイドル」状態は追加されません。

select()、カーネルは回転トレーニング メソッドを使用して fd の準備ができているかどうかを確認します。sockfd は配列のようなデータ構造 fd_set に保存され、キーは fd、値は 0 または 1 です。 。

poll()

[概要]: select と比較した epoll の最大の利点は、sockfd の数が増加しても効率が低下しないことです。

Nginx 関連の技術記事の詳細については、Nginx の使用法チュートリアル 列にアクセスして学習してください。

以上がnginx が高い同時実行性を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Tomcat サーバーへの外部ネットワーク アクセスを許可する方法 Tomcat サーバーへの外部ネットワーク アクセスを許可する方法 Apr 21, 2024 am 07:22 AM

Tomcat サーバーが外部ネットワークにアクセスできるようにするには、以下を行う必要があります。 外部接続を許可するように Tomcat 構成ファイルを変更します。 Tomcat サーバー ポートへのアクセスを許可するファイアウォール ルールを追加します。 Tomcat サーバーのパブリック IP を指すドメイン名を指す DNS レコードを作成します。オプション: リバース プロキシを使用して、セキュリティとパフォーマンスを向上させます。オプション: セキュリティを強化するために HTTPS を設定します。

thinkphpの実行方法 thinkphpの実行方法 Apr 09, 2024 pm 05:39 PM

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

nginx へようこそ!それを解決するにはどうすればよいですか? nginx へようこそ!それを解決するにはどうすればよいですか? Apr 17, 2024 am 05:12 AM

「nginx へようこそ!」エラーを解決するには、仮想ホスト構成を確認し、仮想ホストを有効にし、Nginx をリロードする必要があります。仮想ホスト構成ファイルが見つからない場合は、デフォルト ページを作成して Nginx をリロードすると、エラー メッセージが表示されます。が消え、ウェブサイトは通常のショーになります。

Dockerコンテナ間で通信する方法 Dockerコンテナ間で通信する方法 Apr 07, 2024 pm 06:24 PM

Docker 環境でのコンテナ通信には、共有ネットワーク、Docker Compose、ネットワーク プロキシ、共有ボリューム、メッセージ キューの 5 つの方法があります。分離とセキュリティのニーズに応じて、Docker Compose を利用して接続を簡素化するか、ネットワーク プロキシを使用して分離を強化するなど、最も適切な通信方法を選択します。

phpmyadminの登録方法 phpmyadminの登録方法 Apr 07, 2024 pm 02:45 PM

phpMyAdmin に登録するには、まず MySQL ユーザーを作成して権限を付与し、次に phpMyAdmin をダウンロード、インストール、構成し、最後に phpMyAdmin にログインしてデータベースを管理する必要があります。

Nodejsプロジェクトをサーバーにデプロイする方法 Nodejsプロジェクトをサーバーにデプロイする方法 Apr 21, 2024 am 04:40 AM

Node.js プロジェクトのサーバー デプロイメント手順: デプロイメント環境を準備します。サーバー アクセスの取得、Node.js のインストール、Git リポジトリのセットアップ。アプリケーションをビルドする: npm run build を使用して、デプロイ可能なコードと依存関係を生成します。コードをサーバーにアップロードします: Git またはファイル転送プロトコル経由。依存関係をインストールする: サーバーに SSH で接続し、npm install を使用してアプリケーションの依存関係をインストールします。アプリケーションを開始します。node Index.js などのコマンドを使用してアプリケーションを開始するか、pm2 などのプロセス マネージャーを使用します。リバース プロキシの構成 (オプション): Nginx や Apache などのリバース プロキシを使用して、トラフィックをアプリケーションにルーティングします。

HTMLファイルからURLを生成する方法 HTMLファイルからURLを生成する方法 Apr 21, 2024 pm 12:57 PM

HTML ファイルを URL に変換するには Web サーバーが必要です。これには次の手順が含まれます。 Web サーバーを取得します。 Webサーバーをセットアップします。 HTMLファイルをアップロードします。ドメイン名を作成します。リクエストをルーティングします。

phpmyadmin のインストールが失敗した場合の対処方法 phpmyadmin のインストールが失敗した場合の対処方法 Apr 07, 2024 pm 03:15 PM

失敗した phpMyAdmin インストールのトラブルシューティング手順: システム要件を確認する (PHP バージョン、MySQL バージョン、Web サーバー)、PHP 拡張機能を有効にする (mysqli、pdo_mysql、mbstring、token_get_all)、構成ファイル設定を確認する (ホスト、ポート、ユーザー名、パスワード)、ファイルを確認するアクセス許可 (ディレクトリの所有権、ファイルのアクセス許可)、ファイアウォール設定の確認 (Web サーバー ポートのホワイトリスト)、エラー ログの表示 (/var/log/apache2/error.log または /var/log/nginx/error.log)、テクニカル サポートの問い合わせ ( phpMyAdmin

See all articles