検索
ホームページバックエンド開発PHPチュートリアルPHP ロード バランシング ガイド_PHP チュートリアル

PHP ロード バランシング ガイド_PHP チュートリアル

Jul 21, 2016 pm 02:52 PM
phpweb引きつける大きい応用ガイドサーバ負荷過去走る

これまで、大規模な Web アプリケーションを実行する場合は、大規模な Web サーバーを実行することを意味していました。アプリケーションには多数のユーザーが集まるため、サーバーにメモリとプロセッサを追加する必要があります。
現在、「大規模サーバー」モデルは廃止され、さまざまな負荷分散テクノロジーを使用した多数の小規模サーバーに置き換えられています。これは、ハードウェアのコストを最小限に抑える、より実現可能なアプローチです。過去の「大規模サーバー」モデルに対する「より小規模なサーバー」の利点は 2 つの側面に反映されています。サーバーがダウンすると、負荷分散システムはダウンしたサーバーへの要求を停止し、代わりに正常に実行されている他のサーバーに負荷を分散します。サーバー。
サーバーのスケーリングが簡単になります。必要なのは、負荷分散システムに新しいサーバーを追加することだけです。アプリケーションを中断する必要はありません。
ですから、この機会を活用してください:) もちろん、その代わりに、アプリケーション開発がもう少し複雑になる必要があります。それがこの記事の内容です。
この時点で、「でも、負荷分散を使用していることをどうやって確認すればよいのでしょうか?」と思っているかもしれません。この質問をしている場合の最も正直な答えは、おそらく負荷分散システムを使用していないし、システムは負荷分散システムを考慮する必要がない、というものです。ほとんどの場合、アプリケーションが十分に大きくなると、負荷分散を明示的に提案して設定する必要があります。ただし、Web ホスティング会社が顧客のアプリケーションに対してこの負荷分散を実行しているか、以下で説明するように自社で実行しているのを時々見かけます。
以下に進む前に、この記事では主に PHP の負荷分散について説明していることを指摘しておきます。将来、データの負荷分散について書くかもしれませんが、今は待ってください。
Web サイトではなく「Web アプリケーション」と繰り返し言及していることに注意してください。これは、「Web アプリケーション」が、単純な静的コンテンツを表示するだけの Web サイトではなく、サーバーサイドのプログラミングやデータベースが関与することが多い複雑なサイトであることを区別するためです。
1. PHP ファイル
最初の質問は、小規模サーバーが多数ある場合、PHP ファイルをすべてのサーバーにアップロードするにはどうすればよいですか? 参考までに次の方法があります:
すべてのファイルを各サーバーに個別にアップロードします。この方法の問題点は、サーバーが 20 台あると仮定すると、アップロード プロセス中にエラーが発生しやすく、更新中に異なるサーバー上で異なるバージョンのファイルが発生する可能性が非常に高いということです。
「rsync」(または同様のソフトウェア)を使用すると、ローカルディレクトリ上のファイルと複数のリモートホスト上のディレクトリを同期できます。
バージョン管理ソフトウェア(Subversionなど)を使用する これは私のお気に入りの方法です。これにより、コードを非常に適切に保守できるようになり、アプリケーションを公開するときに、各サーバーで svn update コマンドを実行してアプリケーションを同期できます。このアプローチにより、サーバーを以前のバージョンのコードに切り替えることも簡単になります。
ファイル サーバーを使用する (これには NFS が最適であることがわかります) このアプローチは、ファイル サーバーを使用して Web アプリケーションをホストすることです。もちろん、ファイル サーバーがダウンすると、すべてのサイトがサービス不能になります。 。この時点で、復旧するにはさらに多くのお金が必要になります。
どの方法を選択するかは、あなたのニーズとあなたが持っているスキルによって異なります。バージョン管理システムを使用している場合は、更新コマンドを同時に実行して、すべてのサーバー上のコードを更新する方法を計画するとよいでしょう。ただし、ファイル サーバーを使用する場合は、サーバーがダウンした場合にリクエストの失敗を防ぐために、何らかの障害回復メカニズムを実装する必要があります。
2. ファイルアップロード
サーバーが1台しかない場合、ファイルのアップロードは問題ありません。しかし、複数のサーバーがある場合、アップロードされたファイルはどのように保存されるべきでしょうか? ファイルのアップロードの問題は、クロスサーバーの PHP ファイル ストレージと似ています。考えられる解決策はいくつかあります:
ファイルをデータベースに保存します。ほとんどのデータではバイナリ データを保存できます。ファイルのダウンロードを要求すると、アクセス データはバイナリ データと、対応するファイル名と種類をユーザーに出力します。このソリューションを使用する前に、データベースがファイルをどのように保存するかを検討する必要があります。この方法の問題は、データベース サーバーがダウンするとファイルが使用できなくなることです。
アップロードされたファイルをファイルサーバーに保存する 前の紹介と同様に、すべてのWebサーバーで共有するファイルサーバーをインストールする必要があり、アップロードしたすべてのファイルをここにアップロードすると、すべてのWebサーバーがそれを使用できるようになります。ただし、ファイルサーバーがダウンしている場合、画像ファイルのダウンロードが中断される場合があります。
ファイルを各サーバーに転送するための独自のアップロード メカニズムを設計します。この方法には、単一のファイル サーバーまたはデータベース ソリューションの欠点はありませんが、コードが複雑になります。たとえば、複数のサーバーにアップロード中にサーバーがダウンした場合、どうすればよいでしょうか?
データベースを使用してアップロードされたファイルを保存することもできますが、ファイル キャッシュ メカニズムを設計することは良い解決策です。サーバーはファイルのダウンロード要求を受信すると、まずファイルがキャッシュ システムに存在するかどうかを確認し、存在しない場合はデータベースからファイルを読み取り、ファイル システムにキャッシュします。
3. セッション
PHPのセッション処理に精通している人なら、デフォルトでセッションデータがサーバー上の一時ファイルに保存されることをご存知でしょう。さらに、このファイルはリクエストしたサーバー上にのみ存在しますが、後続のリクエストは別のサーバーによって処理される可能性があり、その結果、他のサーバー上に新しいセッションが生成されます。これにより、ログインしたユーザーが常に再ログインを求められるなど、セッションが頻繁に認識されなくなります。私が推奨する解決策は、PHP の組み込みセッション処理メカニズムを再確立してセッション データをデータベースに保存するか、独自のメカニズムを実装してユーザーのリクエストが確実に同じサーバーに送信されるようにすることです。
4. 設定
今回の話は特にPHPとは関係ありませんが、やはり言及する必要があると思います。クラスター化されたサーバーを実行する場合は、サーバー間で構成ファイルの同期を維持する何らかの方法を用意することをお勧めします。構成ファイルに一貫性がない場合、非常に奇妙な断続的な動作が発生し、トラブルシューティングが困難になる可能性があります。
バージョン管理システムを使って個別に管理することをお勧めします。この方法により、プロジェクトのインストールごとに異なる php 設定ファイルを保存し、すべてのサーバー設定ファイルの同期を保つことができます。
5. ロギング
設定の問題と同様、ロギングは PHP だけに関係するものではありません。ただし、サーバーを健全な状態に維持することは依然として非常に重要です。適切なロギング システムがなければ、PHP コードがエラーを生成し始めたかどうかをどうやって知ることができるでしょうか (システムの実行中は常に display_errors 設定をオフにしますよね?)
ロギングを実装できる方法はいくつかあります:
ロギング各サーバーのログにあります。 これが最も簡単な方法です。各マシンは 1 つのファイルのみを記録します。利点は、シンプルで構成がほとんど必要ないことです。ただし、サーバーの数が増えると、各サーバー上のログ ファイルを監視することが非常に困難になります。 ( 資料 )
共有へのログ記録 この方法でも各サーバーのログ ファイルは残りますが、共有メカニズムを通じて中央のファイル サーバーに保存されるため、ログの監視が容易になります。このソリューションの問題は、ファイル サーバーが利用できない場合、単純なログ書き込みの問題により、最終的にアプリケーション全体がクラッシュすることです。
ロギングサーバーへのロギング syslog などのロギングソフトウェアを使用して、すべてのログを中央サーバーに書き込むことができます。この方法ではさらに多くの構成が必要になりますが、最も堅牢なソリューションも提供されます。

www.bkjia.com本当http://www.bkjia.com/PHPjc/371488.html技術記事以前は、大規模な Web アプリケーションを実行するには、大規模な Web サーバーを実行する必要がありました。アプリケーションには多数のユーザーが集まるため、サーバーにさらに追加する必要があります...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPの抽象クラスまたはインターフェイスに対して、いつ特性を使用しますか?PHPの抽象クラスまたはインターフェイスに対して、いつ特性を使用しますか?Apr 10, 2025 am 09:39 AM

PHPでは、特性は方法が必要な状況に適していますが、継承には適していません。 1)特性により、クラスの多重化方法が複数の継承の複雑さを回避できます。 2)特性を使用する場合、メソッドの競合に注意を払う必要があります。メソッドの競合は、代替およびキーワードとして解決できます。 3)パフォーマンスを最適化し、コードメンテナビリティを改善するために、特性の過剰使用を避け、その単一の責任を維持する必要があります。

依存関係噴射コンテナ(DIC)とは何ですか?また、なぜPHPで使用するのですか?依存関係噴射コンテナ(DIC)とは何ですか?また、なぜPHPで使用するのですか?Apr 10, 2025 am 09:38 AM

依存関係噴射コンテナ(DIC)は、PHPプロジェクトで使用するオブジェクト依存関係を管理および提供するツールです。 DICの主な利点には、次のものが含まれます。1。デカップリング、コンポーネントの独立したもの、およびコードの保守とテストが簡単です。 2。柔軟性、依存関係を交換または変更しやすい。 3.テスト可能性、単体テストのために模擬オブジェクトを注入するのに便利です。

通常のPHPアレイと比較して、SPL SPLFIXEDARRAYとそのパフォーマンス特性を説明してください。通常のPHPアレイと比較して、SPL SPLFIXEDARRAYとそのパフォーマンス特性を説明してください。Apr 10, 2025 am 09:37 AM

SplfixedArrayは、PHPの固定サイズの配列であり、高性能と低いメモリの使用が必要なシナリオに適しています。 1)動的調整によって引き起こされるオーバーヘッドを回避するために、作成時にサイズを指定する必要があります。 2)C言語アレイに基づいて、メモリと高速アクセス速度を直接動作させます。 3)大規模なデータ処理とメモリに敏感な環境に適していますが、サイズが固定されているため、注意して使用する必要があります。

PHPは、ファイルを安全に処理する方法をどのように処理しますか?PHPは、ファイルを安全に処理する方法をどのように処理しますか?Apr 10, 2025 am 09:37 AM

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

Null Coulescingオペレーター(??)およびNull Coulescing Assignment Operator(?? =)とは何ですか?Null Coulescingオペレーター(??)およびNull Coulescing Assignment Operator(?? =)とは何ですか?Apr 10, 2025 am 09:33 AM

JavaScriptでは、nullcoalescingoperator(??)およびnullcoalescingsignmentoperator(?? =)を使用できます。 1.??最初の非潜水金または非未定されたオペランドを返します。 2.??これらの演算子は、コードロジックを簡素化し、読みやすさとパフォーマンスを向上させます。

コンテンツセキュリティポリシー(CSP)ヘッダーとは何ですか?なぜ重要なのですか?コンテンツセキュリティポリシー(CSP)ヘッダーとは何ですか?なぜ重要なのですか?Apr 09, 2025 am 12:10 AM

XSS攻撃を防ぎ、リソースのロードを制限し、ウェブサイトのセキュリティを改善できるため、CSPは重要です。 1.CSPはHTTP応答ヘッダーの一部であり、厳格なポリシーを通じて悪意のある行動を制限します。 2。基本的な使用法は、同じ起源からのロードリソースのみを許可することです。 3.高度な使用法は、特定のドメイン名がスクリプトやスタイルをロードできるようにするなど、より微調整された戦略を設定できます。 4。CSPポリシーをデバッグおよび最適化するには、コンテンツセキュリティポリシーレポートのみのヘッダーを使用します。

HTTPリクエストメソッド(取得、投稿、配置、削除など)とは何ですか?それぞれを使用する必要がありますか?HTTPリクエストメソッド(取得、投稿、配置、削除など)とは何ですか?それぞれを使用する必要がありますか?Apr 09, 2025 am 12:09 AM

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

HTTPSとは何ですか、なぜWebアプリケーションにとって重要なのですか?HTTPSとは何ですか、なぜWebアプリケーションにとって重要なのですか?Apr 09, 2025 am 12:08 AM

HTTPSは、HTTPに基づいてセキュリティレイヤーを追加するプロトコルであり、主に暗号化されたデータを介してユーザーのプライバシーとデータセキュリティを保護します。その作業原則には、TLSの握手、証明書の確認、暗号化された通信が含まれます。 HTTPSを実装する場合、証明書管理、パフォーマンスへの影響、および混合コンテンツの問題に注意を払う必要があります。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版

SublimeText3 中国語版

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

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。