Swoole と Workerman は、PHP 分野で人気のある 2 つの非同期ネットワーク フレームワークであり、MySQL データベースと対話する際のパフォーマンスを大幅に向上させることができます。この記事では、非同期メッセージ処理の観点から開始し、両方の使用法を詳しく紹介し、実用的なコード例を示します。
Swoole は実稼働環境用の非同期ネットワーク通信エンジンであり、コルーチン テクノロジを使用して高性能の非同期 IO 操作を実現します。 MySQL プロトコルのサポートが組み込まれているため、開発者は非同期メソッドを直接使用してデータベース操作を実行できるため、クエリ効率が大幅に向上します。
<?php
$server = new SwooleCoroutineMySQL();
$server->接続する([
'ホスト' => '127.0.0.1',
「ポート」 => 3306、
'ユーザー' => 'ユーザー名前',
「パスワード」 => 「パスワード」、
'データベース' => 'データベース名前',
]);
SwooleRuntime::enableCoroutine();
go(function() use ($server) {
$result = $server->query('SELECT * FROM table1');
var_dump($result);
});
go(function() use ($server) {
$result = $server->query('SELECT * FROM table2');
var_dump($result);
});
SwooleEvent::wait();
?>上記のコードでは、まず Swoole の MySQL オブジェクトを作成してデータベースに接続し、次に go() 関数を通じてコルーチンを開始し、2 つの非同期クエリ操作をそれぞれ実行し、最後に SwooleEvent::wait() を使用してすべてのコルーチンが完了するのを待ちます。
Workerman は、イベント駆動型モデルを使用してネットワーク プログラミングをより柔軟にする、高性能の PHP 非同期通信フレームワークでもあります。非同期 IO 操作を簡単に実装でき、同時実行性の高いシナリオに適しています。
<?php
require_once __DIR__ . '/vendor/autoload.php';
use WorkermanMySQLConnection;
$mysql = new Connection('127.0.0.1', '3306', 'username', 'password', 'dbname');
$worker = new Worker();
$worker-> onWorkerStart = function() use ($mysql) {
$result = $mysql->query('SELECT * FROM table1');
var_dump($result);
$result = $mysql->query('SELECT * FROM table2');
var_dump($result);
};
Worker::runAll();
?>このコードでは、自動ロードを通じて Workerman フレームワークをロードし、MySQL 接続オブジェクトを作成し、Worker オブジェクトの onWorkerStart コールバックで非同期クエリ操作を実行し、最後に Worker::runAll() を通じてイベント ループを開始します。
Swoole と Workerman はどちらも、PHP と MySQL の非同期メッセージ処理を効率的にサポートできます。開発者は、プロジェクトのニーズに基づいて適切なフレームワークを選択し、高速かつ効率的な非同期データベース対話を実現できます。この記事で提供されているサンプル コードは、初心者が非同期メッセージ処理テクノロジが実際のアプリケーションでどのように実装されているかをより深く理解するのに役立つリファレンスとして使用できます。