使用redis pubsub和socket.io

时间:2016-04-28 08:28:12

标签: node.js redis socket.io publish-subscribe node-redis

我正在使用node.js,express创建一个应用程序。今天我尝试使用redis pubsub向关注者发送通知。

当用户登录时,我会检索他的恶魔列表_id并订阅那些_id作为频道名称。当任何用户更新其状态时,他们会向其频道发布通知。在我的脑海中它应该没有任何问题。

但是对于每个用户来说,redis客户端是相同的。因此,如果一个用户订阅了他的朋友_id,那么所有用户都会收到该频道上的消息通知。

我做了什么

在我的app.js文件中 -

...
// Because I wanted to publish from express route , so global
var redis = require('redis');
global.pub = redis.createClient();
global.sub = redis.createClient();
...

...
io.on('connection', function(socket){
  console.log(io.engine.clientsCount + " client connected.");
  global.socket = socket;

  sub.on("message", function(channel, message){
    console.log("Message "+ message + " on channel " + channel+ " arived");
    socket.emit('notification', {data: message});
  });

  socket.on('disconnect', function(){
    console.log(io.engine.clientsCount + " client after disconnecct.");
  });

});

...

在我的routes / user.js文件

...
router.post('/login', function(req, res, next){
...
...
    Friendship.find({user2: req.session.userid}, function(err, doc){
        if (err) return console.dir(err);


        // req.session.followers = _.pluck(doc, 'user1');
        // console.log(req.session);

        /**
         * 
         */
        var userlist = _.pluck(doc, 'user1');
        console.dir(userlist);

        if(userlist.length != 0 ) {
            sub.subscribe(userlist);
        }

        res.redirect('/'); 
    });

和示例发布到频道 -

....
router.post('/progress', function(req, res, next){
    ....
    ....
    myPorgress.save(function(err){
        if(err) console.dir(err);

        pub.publish(req.myAuth.userid, myPorgress);
        res.json({message: "Book progress update successful"});
    });
    ....
});
....

如何为不同的用户创建不同的redis子客户端客户端实例?或者还有其他方法可以做同样的工作吗?

TL; DR

如何在节点js express中实现facebook风格的朋友通知?我可以使用Redis PubSub吗?如果那么如何?

1 个答案:

答案 0 :(得分:0)

我只是使用express-socket.io-session解决了我的问题。当用户登录时,我将其关注者列表保存在会话对象中。

所以我的user.js文件变为

...

var userlist = _.pluck(doc, 'user1');
    req.session.followers = userlist;
    console.dir(userlist);
    res.redirect('/'); 
...

和我的app.js文件

...

io.use(sharedsession(session, {
    autoSave:true
})); 

io.on('connection', function(socket){
  console.log(io.engine.clientsCount + " client connected.");

  //subscribe to friends updates
  var sub = redis.createClient();

  if(socket.handshake.session.followers){
    console.log("subscribing.. to " + socket.handshake.session.followers);
    sub.subscribe(socket.handshake.session.followers);
  }

  sub.on("message", function(channel, message){
    console.log("Message "+ message + " on channel " + channel+ " arived");
    socket.emit('notification', {data: message});
  });

  socket.on('disconnect', function(){
    console.log(io.engine.clientsCount + " client after disconnecct.");
    sub.quit();
  });

});

...