【问题标题】:How to live stream mongodb data to front end with nodejs/mongodb/socketio?如何使用 nodejs/mongodb/socketio 将 mongodb 数据实时传输到前端?
【发布时间】:2016-06-14 09:41:35
【问题描述】:

我正在尝试构建一个实时仪表板,将数据从 mongodb 上限集合流式传输到任何登录用户的前端。后端将是 python 或类似的,并将使用新数据不断更新用户集合。我正在使用passportjs 进行身份验证,并使用passport-socketio-redis 来集成socketio。

我认为的第一个目标是将用户名作为值添加到 socketio 客户端列表中。

示例:连接了一个客户端,客户端列表为:['wukBbRD3vcXCuqylAAAA']。

添加用户值,现在客户端列表如下所示:[ { 'wukBbRD3vcXCuqylAAAA' : username } ]

在此之后,我会定期(每 1 秒左右)循环遍历客户端列表并为每个客户端启动一个 mongodb 流。然后我会使用他们的套接字 ID 将结果数据流式传输到该客户端。 (我假设在断开连接时,客户端 key:val 对将被删除,可能需要添加额外的代码来终止 mongodb 流。)

我想出了下面的代码,它不能正确执行上述操作,因为我目前正试图弄清楚如何将用户名与 socketio 客户端 ID 配对。

这甚至是构建实时仪表板的好方法吗?我越深入,它似乎就越不合理/可扩展。感谢大家的帮助!

/bin/www

var app = require('../app');
var debug = require('debug')('project:server');
var http = require('http');

//misc server initialization stuff left out to save space. this file calls in sockets.js below

var io = require('socket.io').listen(server);
require('../sockets')(io);

sockets.js

var passport = require('passport');
var cookieParser = require('cookie-parser');
var redis = require('redis').createClient();
var session = require('express-session');
var RedisStore = require('connect-redis')(session);
var socketioRedis = require("passport-socketio-redis");
var History = require('./models/history');

var clientinfo;
var user_name;

module.exports = function (io) { 

  io.use(socketioRedis.authorize({
  passport:passport,
  cookieParser: cookieParser,
  key:         'express.sid',       
  secret:      'keyboard cat',    
  store:       new RedisStore({ host: 'localhost', port: 6379, client: redis }),
  success:     authorizeSuccess,  //callback on success
  fail:        authorizeFail     //callback on fail/error 
  }));

function authorizeSuccess(data, accept){
    //get the username
    user_name = data.user.id;
    accept();
}

function authorizeFail(data, message, error, accept)
{
    if(error)
        accept(new Error(message));
}

io.on('connection', function(socket){
  //get list of clients - I believe I need to somehow add the username to the client list here.
  clientinfo = Object.keys(io.engine.clients)
});


setInterval(function(){
  for (key in clientdict) {
    //start new stream for each client (not 100% sure multiple streams can exist)
    streamData (key, clientdict[key])
  }
}
},1000);

//create mongodb stream and emit to client
function streamData (u_id, sockvar) {
    var stream = History.find({ user_id: u_id}, {'_id':0, 'test':1}).tailable(true).stream();
      stream.on('data', function (doc) {
        io.to(sockvar).emit('dash_data', { dash_data: doc });
    });
    }
}

【问题讨论】:

    标签: node.js mongodb socket.io passport.js


    【解决方案1】:

    可能已经解决了这个问题 - 应该更好地阅读文档。事实证明,passport-socketio-redis 允许您访问“socket.request.user”,它返回有关用户的信息。有关在新连接/断开连接时创建和删除键值对的信息,请参见下面的代码

    io.on('connection', function(socket){
      clientdict[socket.request.user.id] = socket.id;
      //console.log(socket.request.user)
      //all clients console.log(Object.keys(io.engine.clients))
      console.log(clientdict)
      socket.on('disconnect', function(){
        delete clientdict[socket.request.user.id]
        console.log('removed')
        console.log(socket.request.user.id)
      });
    });
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-11-03
      • 2020-04-15
      • 1970-01-01
      • 2021-07-05
      相关资源
      最近更新 更多