Heim >Backend-Entwicklung >PHP-Tutorial >Integration und Skalierbarkeit von Nachrichtenwarteschlangen und verteilten Systemen von Swoole und Workerman

Integration und Skalierbarkeit von Nachrichtenwarteschlangen und verteilten Systemen von Swoole und Workerman

WBOY
WBOYOriginal
2023-10-15 16:49:41649Durchsuche

Integration und Skalierbarkeit von Nachrichtenwarteschlangen und verteilten Systemen von Swoole und Workerman

Swoole und Workerman sind beide PHP-Netzwerkkommunikations-Engines. Sie bieten leistungsstarke Integrations- und Erweiterungsmöglichkeiten für Nachrichtenwarteschlangen und verteilte Systeme. In diesem Artikel wird ihre diesbezügliche Anwendung anhand spezifischer Codebeispiele demonstriert.

Werfen wir zunächst einen Blick auf die Eigenschaften von Swoole und Workerman. Swoole ist eine asynchrone PHP-Netzwerkkommunikations-Engine für Produktionsumgebungen. Sie unterstützt TCP/UDP/Unix Socket/HTTP/WebSocket und andere Protokolle und bietet Funktionen wie Timer, asynchrone Aufgaben und Unterprozessverwaltung. Workerman ist ein leistungsstarkes PHP-Socket-Framework, das ein Multiprozessmodell verwendet und massive gleichzeitige Verbindungen verarbeiten kann.

In Bezug auf die Nachrichtenwarteschlange stellt Swoole die onMessage-Rückruffunktion von swoole_server bereit, mit der empfangene Nachrichten in der Nachrichtenwarteschlange gespeichert werden können. Wir können Redis als Nachrichtenwarteschlange verwenden und über die Erweiterung swoole_redis in Swoole integrieren.

<?php
$serv = new swoole_server("127.0.0.1", 9501, SWOOLE_BASE, SWOOLE_SOCK_TCP);

$serv->set([
    'worker_num' => 4,    // 设置工作进程数
]);

$serv->on('WorkerStart', function ($serv, $worker_id) {
    // 连接Redis
    $redis = new Redis();
    $redis->connect('127.0.0.1', 6379);

    // 消息队列名称
    $queue_name = 'message_queue';
    
    // 消费消息队列
    swoole_timer_tick(1000, function () use ($redis, $queue_name) {
        while ($message = $redis->lPop($queue_name)) {
            // 处理消息
            echo "Received message: " . $message . "
";
        }
    });
});

$serv->on('Receive', function ($serv, $fd, $from_id, $data) {
    // 将接收到的消息存入Redis消息队列
    $redis = new Redis();
    $redis->connect('127.0.0.1', 6379);
    $redis->rPush('message_queue', $data);
});

$serv->start();
?>

Im obigen Code haben wir einen Swoole-Server erstellt und die Anzahl der Worker-Prozesse auf 4 gesetzt. In der WorkerStart-Rückruffunktion haben wir Redis verbunden und die Nachrichtenwarteschlange über einen Timer abgefragt, wobei wir die Nachrichtenverarbeitungsfunktion als Rückruffunktion verwendet haben. Wenn eine Nachricht eintrifft, wird die Rückruffunktion onReceive aufgerufen, um die empfangene Nachricht in der Redis-Nachrichtenwarteschlange zu speichern.

Als nächstes werfen wir einen Blick auf die Nachrichtenwarteschlange und die Integrations- und Skalierbarkeitsfunktionen verteilter Systeme von Workerman. Workerman bietet ereignisgesteuerte Entwicklung über seine EventManager-Komponente.

<?php
require_once __DIR__ . '/Workerman/Autoloader.php';

use WorkermanWorker;
use WorkermanRedisQueueClient;
use WorkermanEventLoopSelect;

$worker = new Worker('tcp://127.0.0.1:9501');
$worker->count = 4;

$worker->onWorkerStart = function ($worker) {
    $redis = new PredisClient();
    $queue = new Client($redis);
    
    $queue->onMessage = function ($message) {
        // 处理消息
        echo "Received message: " . $message . "
";
    };
    
    $queue->run();
};

$worker->onMessage = function ($connection, $data) {
    global $worker;
    $worker->queue->sendMessage($data);
};

Worker::$eventLoopClass = Select::class;
Worker::runAll();

Im obigen Code haben wir einen Workerman-Server erstellt und 4 Worker-Prozesse eingerichtet. In der Rückruffunktion onWorkerStart haben wir eine Verbindung zu Redis hergestellt und einen Redis-Warteschlangen-Client erstellt. Verarbeiten Sie Nachrichten, indem Sie die Rückruffunktion onMessage des Warteschlangenclients festlegen. Wenn eine Nachricht empfangen wird, wird die Rückruffunktion onMessage aufgerufen, um die Nachricht an die Redis-Nachrichtenwarteschlange zu senden.

Anhand der obigen Codebeispiele können wir sehen, dass sowohl Swoole als auch Workerman in Nachrichtenwarteschlangen (wie Redis) integriert werden können, um die Nachrichtenübermittlung in verteilten Systemen zu implementieren. In der tatsächlichen Entwicklung können wir geeignete Tools entsprechend den spezifischen Anforderungen auswählen. Sowohl Swoole als auch Workerman bieten gute Erweiterungsmöglichkeiten und können je nach Bedarf angepasst werden.

Das obige ist der detaillierte Inhalt vonIntegration und Skalierbarkeit von Nachrichtenwarteschlangen und verteilten Systemen von Swoole und Workerman. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn