Heim > Backend-Entwicklung > PHP-Tutorial > Lassen Sie uns darüber sprechen, wie PHP es dem Swoole/Pool-Prozesspool ermöglicht, persistente Redis-Verbindungen zu implementieren

Lassen Sie uns darüber sprechen, wie PHP es dem Swoole/Pool-Prozesspool ermöglicht, persistente Redis-Verbindungen zu implementieren

藏色散人
Freigeben: 2023-04-11 10:26:01
nach vorne
4194 Leute haben es durchsucht

Dieser Artikel vermittelt Ihnen relevantes Wissen über PHP und stellt vor allem vor, wie Sie mit PHPphp eine dauerhafte Redis-Verbindung herstellen können. Ich hoffe, dass es für alle hilfreich ist .

Lassen Sie uns darüber sprechen, wie PHP es dem Swoole/Pool-Prozesspool ermöglicht, persistente Redis-Verbindungen zu implementieren

php ermöglicht dem Swoole|Pool-Prozesspool die Implementierung des Redis-Prozesspools für persistente Verbindungen

, basierend auf dem Manager-Verwaltungsprozessmodul von SwooleServer. Im Vergleich zu Process ist es einfacher, mehrere Prozesse zu implementieren, und Entwickler können Prozessverwaltungsfunktionen implementieren, ohne zu viel Code zu schreiben mehrere Kerne CPU-Serverprogramm.

Swoole-Prozesspool implementiert Redis-Datenlesen

Im folgenden Fall wird der Redis-Prozesspool über WorkerStart gestartet und die Redis-Listendaten werden dauerhaft gelesen, wenn WorkerStop alle Verbindungen trennt.

Schritt eins: Kodierungscode

Datei: d10.php

<?php

use Swoole\Process;
use Swoole\Coroutine;

// 指定5个工作进程
$pool = new Process\Pool(5);
// 设置启用协程
$pool->set([&#39;enable_coroutine&#39; => true]);

/**
* onWorkerStart 子进程启动
* @param \Swoole\Process\Pool $pool Pool对象
* @param int $workerId   WorkerId当前工作进程的编号,底层会对子进程进行标号
**/
$pool->on("WorkerStart", function (Process\Pool $pool, $workerId) {
// 输出当前工作进程
   echo "Worker #{$workerId} is started\n";

   // 实例化化连接redis
   $redis = new Redis();
   $redis->pconnect(&#39;127.0.0.1&#39;, 6379);
   // 指定redis键
   $key = "key1";

   // 循环读取列表数据
   while (true) {
    // 弹出列表最后一个元素
       $msgs = $redis->brpop($key, 2);
       // 元素值为空则跳过
       if ( $msgs == null) {
           continue;
       }
       // 打印获取的值
       var_dump($msgs);
       echo "Processed by Worker#{$workerId}\n";
   }
});

// 子进程结束
$pool->on("WorkerStop", function ($pool, $workerId) {
   echo "Worker#{$workerId} is stopped\n";
});

// 启动工作进程
$pool->start();
Nach dem Login kopieren

Schritt zwei: Starten Sie den Redis-Dienst und schreiben Sie Listendaten über den Client

In diesem Fall muss PHP die Redis-Erweiterung installieren

# 通过redis客户端连接
./redis-cli

127.0.0.1:6379> lpush key1 &#39;world&#39;
Nach dem Login kopieren

Kopieren Sie den Code

Dritter Schritt: Führen Sie d10.php aus.

php d10.php
Nach dem Login kopieren
. Schritt 4: Überprüfen Sie den Prozess Die Redis-Liste wird sofort ausgegeben und auf dem Bildschirm ausgedruckt.

Empfohlenes Lernen: „

PHP-Video-Tutorial

Das obige ist der detaillierte Inhalt vonLassen Sie uns darüber sprechen, wie PHP es dem Swoole/Pool-Prozesspool ermöglicht, persistente Redis-Verbindungen zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
php
Quelle:ziruchu.com
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage