【发布时间】: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