使用PHP与Redis的发布订阅模式(redis订阅发布php)

使用PHP与Redis的发布/订阅模式

Redis是一款高性能键值对数据库,除了支持常见的key-value数据类型外,它还支持list、set、sorted set、bitmap等高级数据类型,并提供了一些高级操作,如事务处理、发布/订阅模式等。在本文中,我们将介绍如何使用PHP与Redis的发布/订阅模式实现异步消息传递。

一、Redis发布/订阅模式

Redis的发布/订阅模式实现了一种消息传递机制,适用于解耦异步消息处理。简单来说,发布者发送一条消息,所有订阅者都会收到这条消息。这种模式通常用于消息队列、聊天室、实时通知等场景。Redis的发布/订阅模式可以通过PUBLISH和SUBSCRIBE命令实现。

例如,下面的PHP脚本演示了如何使用PUBLISH命令发布一条消息:

“`php

$redis = new Redis();

$redis->connect(‘127.0.0.1’, 6379);

// 发布一条消息

$redis->publish(‘channel’, ‘hello world’);


在上述代码中,我们先连接Redis服务器,然后使用PUBLISH命令向频道`channel`发布一条消息`hello world`。

而订阅者则可以使用SUBSCRIBE命令订阅该频道,并处理每一条收到的消息。例如:

```php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

// 订阅频道
$redis->subscribe(['channel'], function ($redis, $channel, $message) {
echo "Received message: $message\n";
});

在上述代码中,我们使用SUBSCRIBE命令订阅频道`channel`,并传入一个回调函数,每当有消息发送过来时,该函数都会被调用。例如,当发布者发布一条消息`hello world`时,订阅者的回调函数将输出`Received message: hello world`。

二、使用PHP和Redis实现发布/订阅模式

接下来,我们将演示如何使用PHP与Redis的发布/订阅模式实现异步消息传递。我们将分别编写一个发布脚本和一个订阅脚本,并使用PHP的多进程模块pcntl_fork实现多个订阅者的并发处理。

1. 发布脚本

让我们编写一个发布脚本。该脚本会定时(每秒)向频道`channel`发布一个递增的整数,直到发布10次后退出。

“`php

$redis = new Redis();

$redis->connect(‘127.0.0.1’, 6379);

$count = 0;

while ($count

$count++;

$redis->publish(‘channel’, $count);

sleep(1);

}


在上述代码中,我们使用一个循环来重复向频道`channel`发送消息。注意到我们在每次发送后休眠了1秒,这样可以模拟真实场景中的消息发送间隔。同时,我们还定义了一个计数变量,以此来控制循环的次数。

2. 订阅脚本

接下来,让我们编写一个订阅脚本。该脚本会使用pcntl_fork创建多个子进程来并发处理订阅消息。

```php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

for ($i = 0; $i
$pid = pcntl_fork();
if ($pid == -1) {
die("Could not fork\n");
} elseif ($pid == 0) {
// 子进程
$redis->subscribe(['channel'], function ($redis, $channel, $message) use ($i) {
echo "[$i] Received message: $message\n";
});
exit();
}
}
// 等待子进程退出
while (pcntl_wtpid(0, $status) != -1) {
$status = pcntl_wexitstatus($status);
echo "Child $status exited\n";
}

在上述代码中,我们使用一个循环创建5个进程,并在每个进程中使用SUBSCRIBE命令订阅频道`channel`。为了演示多进程的并发处理,我们在回调函数中输出进程的编号`$i`。使用pcntl_fork创建子进程后,子进程会执行回调函数,等待消息的到来。一旦有消息到来,子进程会输出对应的消息和进程编号,并继续等待下一条消息。

而父进程则使用pcntl_wtpid函数等待所有子进程退出,以确保所有消息都已被处理。在子进程退出后,父进程会输出该子进程的状态信息,例如`Child 0 exited`。

三、运行示例脚本

我们已经编写了发布脚本和订阅脚本,现在可以在控制台中同时运行这两个脚本,以测试我们的发布/订阅模式是否正常工作。

让我们运行发布脚本:

$ php publisher.php

然后,我们在新的控制台窗口中运行订阅脚本:

$ php subscriber.php

我们可以看到,发布者每秒向频道`channel`发送一个递增的数字,而订阅者则不断收到这些数字并输出。由于我们在订阅脚本中使用了多进程,因此多个订阅者可以并发处理这些消息,而不会相互干扰。

当发布脚本超过10次后退出时,我们可以看到订阅脚本也会退出,并输出各个子进程的状态信息。

综上,我们使用PHP与Redis的发布/订阅模式成功地实现了异步消息传递,该模式可用于实现各种异步场景,例如消息队列、聊天室、实时通知等。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/287408.html<

(0)
运维的头像运维
上一篇2025-05-15 20:38
下一篇 2025-05-15 20:39

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注