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'); /** * 计算两点地理坐标之间的距离 * @param Decimal $longitude1 起点经度 * @param Decimal $lati...
(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...
(1)swoole启动的主进程是master进程负责全局管理,然后master进程会再fork一个manager进程。(2)manager进程开始统一管理进程创建回收管理。(3)manager进程根据设置的worker_num和task_worker_num来创建work进程和task进程因此启动s...
在编写多进程的实例中我在每个进程中使用如下代码://调用等待信号的处理器 while (true) { pcntl_signal_dispatch(); }开启5个进程,cpu直接100%修正之后的代码://调用等待信号的处理器 while&...
<?php $member = new class { public function getInfo() { ...
php7.1引入了PHP异步信号处理函数pcntl_async_signals() 来处理阻塞问题。在php7之前信号处理方式有2种,第一种是基于ticks来每执行一行代码来触发执行信号监听,第二种是直接while(true){ //监听信号 }第一种方式如果某行的代码阻塞时间较长会影响...