【php-redis】pub/sub 公开和订阅

网上大多的写法大多直接在终端里的写法,没有一个完整的浏览器直观的例子,直接上代码:

订阅

ini_set(‘default_socket_timeout‘, -1);
$redis = new Redis();
$redis->connect(‘127.0.0.1‘, 6379);
$redis->auth(‘lizongying‘);
$channel = ‘msg‘;
$redis->subscribe(array($channel), ‘callback‘);

function callback($redis, $channel, $message)
{
    if (ob_get_level() == 0) {
        ob_start();
    }
    echo str_pad(‘ ‘, 1024 * 8);
    echo date(‘Y-m-d H:i:s‘);
    var_dump($message);
    flush();
    ob_flush();
    ob_end_flush();
}

公开

$redis = new Redis();
$redis->connect(‘127.0.0.1‘,6379);
$redis->auth(‘lizongying‘);
$channel = ‘msg‘;  // channel
$msg = ‘33‘; // msg
$redis->publish($channel, $msg);
echo date(‘Y-m-d H:i:s‘);
var_dump($channel.$msg);

几个点:

1 在命名空间内

new \Redis();

2 如果有密码

$redis->auth(‘lizongying‘);

3 保证socket不超时

ini_set(‘default_socket_timeout‘, -1);

4 及时刷新 测试用的chrome buffer长度加到了1024*8才起作用 一些教程里是1024 或者 4096

    if (ob_get_level() == 0) {
        ob_start();
    }
    echo str_pad(‘ ‘, 1024 * 8);
    echo date(‘Y-m-d H:i:s‘);
    var_dump($message);
    flush();
    ob_flush();
    ob_end_flush();

保健食品注册咨询专家

时间: 2024-10-18 18:34:35

【php-redis】pub/sub 公开和订阅的相关文章

redis pub/sub 发布订阅

Redis的列表数据结构有blpop和brpop命令,能从列表里返回且删除第一个(或最后一个)元素,或者被堵塞,直到有一个元素可供操作.这可以用来实现一个简单的队列. (译注:对于blpop和brpop命令,如果列表里没有关键字可供操作,连接将被堵塞,直到有另外的Redis客户端使用lpush或rpush命令推入关键字为止.) 此外,Redis对于消息发布和频道订阅有着一流的支持.你可以打开第二个redis-cli窗口,去尝试一下这些功能.在第一个窗口里订阅一个频道(我们会称它为warnings

Redis系列(三)—— 订阅/发布

Redis 订阅/发布 参考:http://www.cnblogs.com/mushroom/p/4470006.html,http://www.tuicool.com/articles/ABry2aj,http://www.cnblogs.com/tinywan/p/5903256.html,http://www.cnblogs.com/linjiqin/p/5733183.html,http://redisbook.readthedocs.io/en/latest/feature/pubsu

Redis中的发布与订阅

redis中实现发布与订阅相对于zookeeper非常简单.直接使用publish和subscribe就行. subscrible news; 订阅news这个channel publish news  a-dog-eat-a-pig 在news这个channel就接受到信息

【02】Redis for OPS:消息订阅和事务管理

写在前面的话 上一节谈了 Redis 的安装以及五种基本数据类型的一些简单的操作,本章节主要看看 Redis 的另外一些特征,虽然可能不常用,但是还是需要了解的.对于我们运维人员来讲,这些东西更像拓展的知识,可能我们工作很多年都不会用到,但是当你慢慢的需要往运维开发方向发展以后,这些东西就会成为你解决问题的又一方案.另外一种思路. 发布订阅 Redis 发布消息一般有两种方式,消息队列和发布订阅. 对于消息队列,其角色包含:生产者 --> 消息队列 --> 消费者 生产者讲需要处理的任务放到队

python redis 实现简单的消息订阅

python + redis 实现简单的消息订阅 订阅端 import redis from functools import wraps class Subscribe: def __init__(self, channel: str, **kwargs): self.coon = redis.StrictRedis(**kwargs) self.channel = channel self.registerd = list() self.course = self.coon.pubsub()

使用redis pub/sub 时间订阅与发布消息

import redis import time r=redis.StrictRedis(host="127.0.0.1",port=6379) #你也可以选择使用地址池的方式建立连接 while True: if __name__='__main__': dis=Get_Distance() p=r.publish() p.subscribe("first channel") #订阅 r.publish("first channel",dis)

Spring Data Redis—Pub/Sub(附Web项目源码)

一.发布和订阅机制 当一个客户端通过 PUBLISH 命令向订阅者发送信息的时候,我们称这个客户端为发布者(publisher). 而当一个客户端使用 SUBSCRIBE 或者 PSUBSCRIBE 命令接收信息的时候,我们称这个客户端为订阅者(subscriber). 为了解耦发布者(publisher)和订阅者(subscriber)之间的关系,Redis 使用了 channel (频道)作为两者的中介 —— 发布者将信息直接发布给 channel ,而 channel 负责将信息发送给适当

Spring Data Redis—Pub/Sub(附Web项目源码) (转)

一.发布和订阅机制 当一个客户端通过 PUBLISH 命令向订阅者发送信息的时候,我们称这个客户端为发布者(publisher). 而当一个客户端使用 SUBSCRIBE 或者 PSUBSCRIBE 命令接收信息的时候,我们称这个客户端为订阅者(subscriber). 为了解耦发布者(publisher)和订阅者(subscriber)之间的关系,Redis 使用了 channel (频道)作为两者的中介 —— 发布者将信息直接发布给 channel ,而 channel 负责将信息发送给适当

redis pub/sub Spring StringRedisTemplate

redis 订阅发布 项目名称:SmRemind_NEW @Service public class PubServiceImpl implements PubService { @Resource(name="stringRedisTemplate") private  StringRedisTemplate stringRedisTemplate; private String channelTopic = "Baojing"; /*发布消息到Channel*/