我正在尝试使用hiredis客户端通过c ++测试redis的这个pub / sub函数。
我可以看到订阅某个频道似乎很容易通过redisCommand Api完成。
但是我想知道当有人发布到某个服务器时,回复是如何回来的。
谢谢
答案 0 :(得分:2)
https://github.com/redis/hiredis/issues/55 aluiken于2012年3月2日发表评论
void onMessage(redisAsyncContext *c, void *reply, void *privdata) {
redisReply *r = reply;
if (reply == NULL) return;
if (r->type == REDIS_REPLY_ARRAY) {
for (int j = 0; j < r->elements; j++) {
printf("%u) %s\n", j, r->element[j]->str);
}
}
}
int main (int argc, char **argv) {
signal(SIGPIPE, SIG_IGN);
struct event_base *base = event_base_new();
redisAsyncContext *c = redisAsyncConnect("127.0.0.1", 6379);
if (c->err) {
printf("error: %s\n", c->errstr);
return 1;
}
redisLibeventAttach(c, base);
redisAsyncCommand(c, onMessage, NULL, "SUBSCRIBE testtopic");
event_base_dispatch(base);
return 0;
}
答案 1 :(得分:1)
这是一个较晚的答案,但是您可以尝试基于hiredis并以C ++ 11编写的redis-plus-plus。
免责声明:我是该库的作者。如果您对此客户有任何疑问,请随时let me know。如果您喜欢它,也可以随时对其进行标记:)
示例代码:
Redis redis("tcp://127.0.0.1:6379");
// Create a Subscriber.
auto sub = redis.subscriber();
// Set callback functions.
sub.on_message([](std::string channel, std::string msg) {
// Process message of MESSAGE type.
});
sub.on_pmessage([](std::string pattern, std::string channel, std::string msg) {
// Process message of PMESSAGE type.
});
sub.on_meta([](Subscriber::MsgType type, OptionalString channel, long long num) {
// Process message of META type.
});
// Subscribe to channels and patterns.
sub.subscribe("channel1");
sub.subscribe({"channel2", "channel3"});
sub.psubscribe("pattern1*");
// Consume messages in a loop.
while (true) {
try {
sub.consume();
} catch (...) {
// Handle exceptions.
}
}
检查doc以获得详细信息。
答案 2 :(得分:0)
观察者模式是我们在Redis的pub / sub特性中看到的。
所有订阅者都是观察者,主题是发布者正在修改的频道。
当发布者修改频道时,即执行像redis-cli&gt;这样的命令。发布foo值 Redis服务器将此更改传达给所有观察者(即订阅者)
因此Redis服务器具有特定频道的所有观察者的列表。