swoole の 2 つの動作モードの紹介:
シングルスレッド モード (SWOOLE_BASE)
これモードは従来の非同期ノンブロッキング サーバーです。 Nginx や Node.js などのプログラムと完全に一致しています。
配信タスクをディスパッチする代わりに、タイム ループ内で PHP 関数を直接コールバックします。コールバック関数にブロック操作がある場合、サーバーは同期モードに縮退します。 worker_num パラメータは BASE モードでも有効であり、複数の Worker プロセスが開始されます。
BASE モードにはマスター プロセスの役割はありません
各ワーカー プロセスは、プロセス モードのリアクター スレッドとワーカー プロセスの役割も引き受けます
BASE のマネージャー プロセスモードはオプションです。worker_num=1 が設定され、Task 機能と MaxRequest 機能が使用されていない場合、最下層は Manager プロセスを作成せずに別の Worker プロセスを直接作成します。
BASE モードの利点:
BASE モードには IPC オーバーヘッドがなく、パフォーマンスが優れています
BASE モードのコードはシンプルでエラーが発生しにくくなっています
BASE モードの欠点:
TCP 接続は維持されます。ワーカー プロセス 。そのため、ワーカー プロセスがハングアップすると、このワーカー内のすべての接続が閉じられます。
少数の長い TCP 接続はすべてのワーカー プロセスで使用できません。
TCP 接続はバインドされます。ワーカーへの接続 長時間接続アプリケーションの特定の接続には大量のデータが含まれており、これらの接続が配置されているワーカー プロセスの負荷は非常に高くなります。ただし、一部の接続のデータ量は小さいため、ワーカー プロセスの負荷は非常に低くなり、異なるワーカー プロセスのバランスが取れなくなります。
BASE モードの適用可能なシナリオ:
クライアント接続間の対話が必要ない場合は、BASE モードを使用できます。 Memcache、HTTP サーバーなど。
推奨学習: swoole ビデオ チュートリアル
プロセス モード (SWOOLE_PROCESS)
マルチプロセス モードは、最も複雑 この方法では、多くのプロセス間通信とプロセス管理メカニズムが使用されます。非常に複雑なビジネス ロジックを含むシナリオに適しています。 Swoole は、完全なプロセス管理とメモリ保護メカニズムを提供します。ビジネスロジックが非常に複雑な場合でも、長時間安定して動作します。
Swoole は、Reactor スレッドに Buffer 関数を提供します。これは、多数の遅い接続とバイト単位の悪意のあるクライアントに対処できます。さらに、プログラムをより効率的に実行するための CPU アフィニティ設定オプションが提供されています。
プロセス モードの利点:
接続とデータ リクエストの送信が分離され、一部の接続には大量のデータが含まれ、一部には少量のデータが含まれるため、ワーカー プロセスのバランスが崩れることはありません。
##Worker プロセスが致命的なエラーを送信した場合、接続は切断されません 単一接続の同時実行を実現でき、少数の TCP 接続のみが維持され、リクエストを同時に処理できます。複数のワーカー プロセスで使用可能 プロセス モードの欠点: 2 つの IPC のオーバーヘッドがあり、マスター プロセスとワーカー プロセスは通信に UnixSocket を使用する必要があります sendwait、一時停止、再開、その他の操作など、いくつかの高度な機能をサポートします以上がスウールはどのように機能しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。