nginx の概要
Nginx (「エンジンx」と発音)は、ロシアのソフトウェアエンジニアIgorによって開発されたソフトウェアです Sysoevによって書かれたオープンソースのwebサーバー。 2004年のリリース以来、nginxは、高性能、高同時実行性、低メモリ使用量に重点を置いており、負荷分散やキャッシュ、アクセス、帯域幅の制御、およびさまざまなアプリケーションと効果的に統合する機能により、nginxは最新のウェブサイトアーキテクチャにとって良い選択となります。現在、nginxは、インターネット上で最も人気のあるwebサーバーソフトウェアのリストで2位にランクされています。 1.
なぜ高い同時実行性がそれほど重要なのでしょうか? 現在、インターネットは非常に人気があり、どこにでも普及していますが、これは10
年前には想像するのが難しかったことを私たちは知っています。さらに、クリック可能なテキストは、NCAS (訳者注: National Center for Supercomputer Applications ) に基づいた単純な HTML から Apache ベースに生成されるため、 ウェブサービスの大きな進化により、インターネットは世界中の2人のネットユーザーにとって共通のコミュニケーションメディアとなりました。コンピューター、モバイル デバイス、そして最近ではタブレットの拡大を続ける普及により、インターネット空間と経済全体の有線デジタル化が急速に変化しています。オンライン サービスもさらに詳細になり、リアルタイムで効果的な生活情報やエンターテイメント情報が提供されています。そして、オンライン ビジネスのセキュリティ面にも大きな変化が生じています。その結果、Web サイトは以前よりも複雑になり、インターネットをより堅牢かつスケーラブルにするために、より多くのエンジニアリング作業が必要になりました。 Web サイトのアーキテクチャにおける最大の課題は同時実行性です。 Network サービスの開始当初から、同時実行レベルは増加し続けてきました。 Web サイトが同時に数百、数千、さらには数百万のユーザーにサービスを提供することも珍しくありません。 10 年前、同時実行の原因はクライアントの遅さでした
- 当時、ユーザーは接続に ADSL またはダイヤルアップを使用していました 現在では 、 同時実行はモバイル クライアントによって駆動されており、一部のクライアントではpersist through ニュース、ツイート、友人メッセージなどを更新するために接続する、更新されたアプリケーション アーキテクチャの組み合わせ。同時実行性の増加を引き起こすもう 1 つの要因は、最新のブラウザーが Web ページを読み込むために同時に Web サイトに対して 4 から 6 の接続を開き、ページの読み込み速度を上げることです。 クライアントが遅い場合の問題を説明するために、100kサイズの応答テキストまたは画像を生成できる
apacheに基づく単純なwebサービスがあると仮定します。サービス このページの生成またはクエリにはほんの 1 秒しかかかりませんが、80kbps (10kB/s) 帯域幅を持つクライアントでは、このリクエストを送信するのに 10 秒かかります。 web サービスは 100k コンテンツをすぐにプルできましたが、接続が解放されるまでに 100k コンテンツを送信するのに 10 秒かかりました。ここで、同様のコンテンツをリクエストする同時接続クライアントが 1M 割り当てられている場合、これらの 1000クライアントを満たすには、100K のリクエストが必要になると想定します。 には1000M (約1G)の追加メモリが必要です。実際、apacheに基づく標準のwebサービスは、通常、接続ごとに1Mを超えるメモリを割り当てますが、悲しいことに、モバイル通信の実効速度はわずか数十 kpbsです。遅いクライアントにコンテンツを送信する問題は、オペレーティング システム カーネルの socket バッファリングによってある程度軽減される可能性がありますが、これは普遍的な解決策ではなく、予期せぬ悪影響を与える可能性があります。 永続的な接続の処理により、同時実行の問題がより顕著になります。これは、http接続の再作成によって引き起こされる遅延を回避するために、クライアントは常にwebサーバーに接続したままにする必要があるためです。 , web サービスは、接続ごとに追加のメモリ空間も割り当てます。
したがって、ユーザー数の増加によって引き起こされる増加する負荷を継続的に処理し、より高い同時実行性を得るには、一連の非常に高性能なモジュールに基づいて Web サイトを構築する必要があります。ただし、ハードウェア(CPU、メモリ、ハードディスク)、ネットワーク容量、アプリケーションおよびデータストレージアーキテクチャなどの他の部分も明らかに同様に重要であり、ウェブサーバーを決定します。受け入れられ処理されたクライアント接続の数。したがって、webサーバーは、非線形スケーリングを通じて、増加する1秒あたりの同時接続数とリクエスト数に対応できる必要があります。
Apacheは適していますか? 1990 年代初頭に誕生した
Apache は、今でもインターネット上で有力な web サーバー ソフトウェアです。 2000 年以降、増加するネットワーク サービスに合わせてスタンドアロン Web サービスを簡単に複製できないことが明らかになりました。 Apache は将来の開発のための強固な基盤を提供しますが、新しい接続ごとに Apache 自体のコピーを作成するそのアーキテクチャは、Web サイトの非線形拡張の要件を満たすことができません。最終的に、Apache はさまざまなサードパーティ製プラグインを備えた完全に機能する Web サーバーとなり、あらゆる種類の二次開発 Web サイトにほぼ普遍的に適用できるようになりました。しかし、それほど重くなるのは良いことではありません。欠点は、非常に多くの機能とツールを 1 つのソフトウェアに組み合わせると、各接続のコストも増加することです。 したがって、CPU とメモリの使用量により、ソフトウェアのスケーラビリティが低下します。
そのため、サーバー ハードウェア、オペレーティング システム、およびネットワーク リソースが Web サイトの成長を制限する主な要因ではなくなったため、世界中の開発者は Web サーバーを実行するためのより効果的な方法を模索し始めています
C10K リストの 10,000 同時接続の問題を解決するために、nginx は別のアーキテクチャ、つまり同時接続数と 1 秒あたりのリクエスト数の両方の非線形拡張により適したアーキテクチャを検討しました。 。 nginx はイベント モデルに基づいているため、新しいプロセスをそれぞれ複製したり、ページごとに個別のスレッドを作成したりする Apache のルールには従いません。その結果、負荷が増加してもメモリと CPU の使用量は制御可能な状態を維持できるため、nginx は通常のハードウェアを備えた単一サーバー上で数万の同時リクエストを処理できます。
nginx 最初のバージョンは、HTML、CSS、JavaScript スクリプトや画像など、Apache ベースのアプリケーション サーバーの Apache にデプロイされた静的コンテンツの同時実行性とタイムアウト処理を nginx 経由でオフロードするためにリリースされました。 nginx は開発中に、FastCGI、uswgi、または SCGI プロトコルを使用してサードパーティ アプリケーションと統合し、memcache のような分散オブジェクト キャッシュ システムを備えています。同時に、負荷分散メカニズムやキャッシュを備えたリバース プロキシなど、いくつかの便利な機能が追加されました。これらの追加機能により、nginx はスケーラブルな Web ベースのインフラストラクチャを構築するためのツールの効果的な組み合わせになります。
nginx を使用すると他にも利点がありますか?
通常、大規模な同時リクエストの効率的かつ高パフォーマンスな処理が nginx の主な利点であると同時に、nginx の使用には他の利点もあります。
ここ数年、ネットワーク アーキテクトは疎結合の考えを受け入れ、アプリケーションの基礎となるコンポーネントを Web サービスから分離し始めました。ただし、LAMP (Linux、Apache、MYSQL、PHP、Python、または Perl) に基づく以前の既存の Web サイトには、LEMP (E は「エンジン x」と発音します) に基づく Web サイトが含まれる可能性があり、実際の Web サーバーはますます一般的になりつつあります。インフラストラクチャのエッジにプッシュする必要があるか、同じまたはいくつかの新しいアプリケーションとデータ ツールをさまざまな方法で統合する必要があります。
nginx は上記の状況に非常に適しています。これは、nginx が、同時実行性のオフロードなど、アプリケーション層からより効率的なエッジサーバー (翻訳者注: 馴染みのない読者はエッジサーバーにクエリを実行できます) 層までいくつかの主要な機能を提供するためです。タイムアウト処理、SSL (Secure Socket Layer)、コンテンツの静的化、圧縮とキャッシュ、接続とリクエストのスロットリング、さらには HTTP ストリーミング。同時に、nginx は memcached、Redis、およびその他の NoSQL ソリューションと直接統合して、大規模な同時ユーザーの下でのパフォーマンスを向上させることもできます。
最新のオープン ツール コンポーネントとプログラミング言語の人気により、ますます多くの企業がアプリケーションの開発と展開の習慣を変え始めています。そして、nginx はこの種の変化のモデルとなり、最も重要なコンポーネントの 1 つに発展すると同時に、多くの企業が予算内で Web サービスの持続的かつ迅速な開発を達成するのにも役立ちました。 nginx のコードの最初の行は 2002 年に書かれ、2004 年までに nginx は 2-2-clause BSD ライセンスの下でリリースされました。 nginx がリリースされて以来、そのユーザー ベースは成長を続けており、アイデアの提供、バグの送信、さまざまなコメントや提案を行うことでコミュニティ全体に大いに役立っています。 nginx のコードベースはオリジナルであり、完全に C 言語で実装されています。また、Linux、FreeBSD、Solaris、Mac OS X、AIX、Windows システムなど、さまざまなアーキテクチャのオペレーティング システムにも移植されています。 nginx には独自のライブラリもあり、これらのライブラリは、zlib、PCRE、OpenSSL に加えて、必要のないライブラリや、ライセンスが競合する可能性のあるライブラリを削除できます。 Windows バージョンの nginx について少し話しましょう。 Windows で実行される nginx は、完全に機能するポートというよりも概念実証にすぎません。 Nginx には Windows でも制限があります。つまり、nginx は Windows カーネルとの互換性が高くありません。Windows の以前のバージョンの nginx の既知の問題には、同時サポートの少なさ、パフォーマンスの低下、キャッシュの失敗、帯域幅ポリシーの失敗などがあります。将来的には、Windows バージョンの nginx は主流の機能とより一貫性のあるものになる予定です。
上記はさまざまな側面を含む nginx の紹介です。PHP チュートリアルに興味のある友人に役立つことを願っています。

ホット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)

ホットトピック









1. 58 Portraits プラットフォーム構築の背景 まず、58 Portraits プラットフォーム構築の背景についてお話ししたいと思います。 1. 従来のプロファイリング プラットフォームの従来の考え方ではもはや十分ではありません。ユーザー プロファイリング プラットフォームを構築するには、複数のビジネス分野からのデータを統合して、ユーザーの行動や関心を理解するためのデータ マイニングも必要です。最後に、ユーザー プロファイル データを効率的に保存、クエリ、共有し、プロファイル サービスを提供するためのデータ プラットフォーム機能も必要です。自社構築のビジネス プロファイリング プラットフォームとミドルオフィス プロファイリング プラットフォームの主な違いは、自社構築のプロファイリング プラットフォームは単一のビジネス ラインにサービスを提供し、オンデマンドでカスタマイズできることです。ミッドオフィス プラットフォームは複数のビジネス ラインにサービスを提供し、複雑な機能を備えていることです。モデリングを提供し、より一般的な機能を提供します。 2.58 中間プラットフォームのポートレート構築の背景のユーザーのポートレート 58

同時実行テストとデバッグ Java 同時プログラミングにおける同時実行テストとデバッグは非常に重要であり、次の手法が利用可能です。 同時実行テスト: 単体テスト: 単一の同時タスクを分離してテストします。統合テスト: 複数の同時タスク間の相互作用をテストします。負荷テスト: 高負荷時のアプリケーションのパフォーマンスとスケーラビリティを評価します。同時実行デバッグ: ブレークポイント: スレッドの実行を一時停止し、変数を検査するかコードを実行します。ロギング: スレッドのイベントとステータスを記録します。スタック トレース: 例外のソースを特定します。視覚化ツール: スレッドのアクティビティとリソースの使用状況を監視します。

WordPressサイトファイルアクセスが制限されています:最近.txtファイルにアクセスできない理由のトラブルシューティング。一部のユーザーは、ミニプログラムのビジネスドメイン名を構成する際に問題に遭遇しました:�...

クラウド コンピューティングでは、大量のデータを管理および処理するために、データ構造とアルゴリズムの使用が不可欠です。一般的なデータ構造には、配列、リスト、ハッシュ テーブル、ツリー、グラフなどがあります。一般的に使用されるアルゴリズムには、並べ替えアルゴリズム、検索アルゴリズム、グラフ アルゴリズムなどがあります。 Java の機能を活用することで、開発者は Java コレクション、スレッドセーフなデータ構造、および Apache Commons Collection を使用して、これらのデータ構造とアルゴリズムを実装できます。

Java ネットワーク プログラミングで一般的に使用されるプロトコルとライブラリ: プロトコル: TCP、UDP、HTTP、HTTPS、FTP ライブラリ: java.net、java.nio、ApacheHttpClient、Netty、OkHttp

同じシステムで複数のPHPバージョンを同時に実行することは、特に異なるプロジェクトがPHPの異なるバージョンに依存する場合、一般的な要件です。同じようになる方法...

PHP マイクロサービス コンテナ化展開の完全ガイド はじめに マイクロサービス アーキテクチャは、アプリケーションを独立した疎結合サービスに分解する、現代のソフトウェア開発におけるホットなトレンドとなっています。コンテナ化は、これらのマイクロサービスをデプロイおよび管理するための効果的な方法を提供します。この記事では、PHPDocker を使用してマイクロサービスをコンテナ化してデプロイするのに役立つステップバイステップのガイドを提供します。 Docker の基本 Docker は、アプリケーションとそのすべての依存関係をポータブル コンテナーにパッケージ化する軽量のコンテナー化プラットフォームです。次の手順では、Docker の使用方法を説明します。 #Install Dockersudoapt-getupdatesudoapt-getinstalldock

多くのウェブサイト開発者は、ランプアーキテクチャの下でnode.jsまたはPythonサービスを統合する問題に直面しています:既存のランプ(Linux Apache MySQL PHP)アーキテクチャWebサイトのニーズ...
