Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者(publisher),订阅者(subscriber)和频道(channel)。
发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个频道的订阅者就能接收到这条消息。
关系图如下:

【一】.现在模拟下发布消息到对应频道,订阅对应频道接收消息。假设我们现在有一个名为FM88.7的redis频道(哈哈,这是中国国际广播电台的频道)
(1). Redis采用SUBSCRIBE命令订阅某个频道。现在我们订阅下FM88.7频道,命令是:SUBSCRIBE 频道名称 (可以多开几个命令行窗口当做是多个人订阅这个频道),其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道。
SUBSCRIBE FM88.7 //执行后窗口一直挂起在接收频道信息
(2). Redis采用PUBLISH命令发送消息到对应频道。现在我们发送消息到FM88.7,让订阅的人都收到,命令为:PUBLISH 频道名称 消息内容 ,其返回值为接收到该消息的订阅者的数量。
PUBLISH FM88.7 "welcome to fm88.7" //返回2,因为在第一步我开启了2个窗口,相当于2个人订阅这个频道
(3). 从上面来看,我们必须要知道这个频道才能去收听频道的内容,那我能不能和FM收音机一样支持自动搜索呢?支持的,Redis提供Psubscribe 命令订阅一个或多个符合给定模式的频道。每个模式以 * 作为匹配符。警告:如果你使用普通订阅和这个匹配订阅同时订阅一个频道,这个频道的消息你每次都会收到2条,只不过这两条消息的类型不同,一个是message类型,一个是pmessage类型,但其内容相同。
Psubscribe * //订阅所有频道 Psubscribe news* //订阅所有以news开头的频道
(4). 退订频道命令是:
UNSUBSCRIBE 频道名称 //单个退订 UNSUBSCRIBE * //全部退订 UNSUBSCRIBE news* //退订所有以news开头的频道
【二】.PHP代码实现。由于订阅频道后客户端是阻塞的接收信息,所以订阅者都是以cli模式运行。
(1).redis.php:连接redis,返回redis对象
<?php
($redis = new Redis())->connect('127.0.0.1', 6379); (2)sub.php:订阅者,开启2个cli运行
<?php
include './redis.php';
global $redis;
/**
* 参数1: 传递需要订阅的频道数组,支持多个
* 参数2: 传递回调函数
*/
$redis->subscribe(['FM88.7'],function (Redis $instance, $channel, $message){
echo '频道:'.$channel.PHP_EOL;
echo '消息:'.$message.PHP_EOL;
});(3)pub.php:发布者
<?php
include './redis.php';
global $redis;
/**
* 参数1: 频道名称
* 参数2: 频道消息
*/
$result = $redis->publish('FM88.7', 'welcome to fm88.7'); 项目中使用服务来执行webservice,由于对方系统api不稳定,经常导致服务崩溃,只能重启,一个月差不多要重启一次。初期的解决办法是捕获异常,然后continue掉。<?php try { $url = 'http...
在编写多进程的实例中我在每个进程中使用如下代码://调用等待信号的处理器 while (true) { pcntl_signal_dispatch(); }开启5个进程,cpu直接100%修正之后的代码://调用等待信号的处理器 while&...
将jsonp转为PHP数组和对象。/** * jsonp转数组|Jsonp转json * @param string $jsonp jsonp字符串 * @param bool $as...
第一次听说端口复用是在mixphp最新版本中发现的,mixphp启动监听9501端口,现在作者说可以多开几个进程来执行mixphp,我心里想了下再启动不是会端口冲突嘛,但是却没有问题,于是下载mixphp的源码解读,原来是启动http服务器使用new Co\Http\Server('0.0....
最近在项目中处理一个关于商品数据重复需要删除多余的商品记录,但是删除一条商品必然要把关联的其他表商品的id和其他商品信息更换为正确的,删除一个商品记录,同时要去修改100多张表的关联商品数据,在项目中引用了tp orm 1.2版本,由于项目是php5.6版本,没法使用最新orm,在代码中每处理1个商...
本教程使用的定时任务基于EasyTak,EasyTask官方文档:https://gitee.com/392223903/EasyTask(1).安装tp5.0或者5.1composer create-project topthink/think=5.0.* tp5&n...