目前我正在使用node.js和redis构建一个应用程序,我使用redis的原因是因为它具有发布/订阅功能。该应用程序的简单作用是在用户进入或离开房间时通知管理员。
function publishMsg( channel , mssage){
redisClient.publish(channel,JSON.stringify());
}
publishMsg('room/1/user/b',{'room':1,'user':'b'});
publishMsg('room/1/user/c',{'room':1,'user':'c'});
publishMsg('room/2/user/b',{'room':2,'user':'b'});
publishMsg('room/2/user/c',{'room':2,'user':'c'});
function subscribe(pattern){
redisClient.psubscribe(pattern);
redisClient.on('pmessage', function(pattern, channel, message){
console.log('on publish / subscribe ', pattern+" "+channel+" "+message+" "+ JSON.parse( message) );
});
}
因为我想监听加入和离开事件,所以我的问题是,是否应该使用两个 Redis 客户端来监听这两个事件,比如:
redisClient1.psubscribe('room/*/user/*/join');
redisClient2.psubscribe('room/*/user/*/disjoin');
或者只使用一个redis客户端来监听并在回调函数内分离逻辑。
redisClient2.psubscribe('room/*/user/*');
我知道这两种方法都是可行的,但我不知道在现实中人们如何使用它们,在什么情况下?