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'); Session在默认情况下是使用客户端的Cookie来保存Session ID的,所以当客户端的cookie出现问题的时候就会影响Session了,如果你单纯的认为SESSION和COOKIE没有联系的话请迅速百度补脑。 &nbs...
为了实现注册机才写的教程,为了批量注册一个网站,注册带有验证码,幸好是文本验证码,但是有session验证,于是POST必须携带cookie。代码如下。<?php class AutoCurl{ ...
原理:使用curl_init()创建多个请求实例,再使用curl_multi_init()批量执行创建的多个请求实例。文件1:curl.php<?php $threads=500;//并发请求次数 $url='http://blog.cn/index.php?';...
首先看看以下代码:代码1:<?php $a=0.1; $b=0.7; if($a+$b==0.8) { echo "1"; } else{ echo "2"; } ?>代码2:<?php &n...
第一步:服务端文件<?php $wsdlfile='webservice.wsdl'; ini_set('soap.wsdl_cache_enabled','0'); //关闭WSDL缓存 //001...
(1)swoole启动的主进程是master进程负责全局管理,然后master进程会再fork一个manager进程。(2)manager进程开始统一管理进程创建回收管理。(3)manager进程根据设置的worker_num和task_worker_num来创建work进程和task进程因此启动s...