ホームページ  >  記事  >  バックエンド開発  >  nginx の概要

nginx の概要

WBOY
WBOYオリジナル
2016-08-08 09:21:231083ブラウズ

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 サーバーを実行するためのより効果的な方法を模索し始めています約10年前、有名なソフトウェアエンジニアであるダニエルは Kegel 氏は、「Web サーバーの同時リクエストは数万件にとどまる時代が来た」と主張し、現在インターネット クラウド サービスと呼ばれるものを予測しました。 Kegel の C10K リストには、Web サーバーの最適な状態での同時接続数の問題を解決するいくつかの試みも含まれており、最終的には nginx が最も効果的なソリューションであることが証明されました。

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 チュートリアルに興味のある友人に役立つことを願っています。

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