nodejs 多进程 Session 共享问题探讨
发布于 2年前 作者 xiexinze 2077 次浏览

nodejs 用 cluster 模块实现多进程 启动,刚开始 心喜

if (cluster.isMaster) { var numCPUs = require(‘os’).cpus().length; var data = 0; // 启动多个进程. for (var i = 0; i < numCPUs; i++) { //增加一个进程 var worker_process = cluster.fork(); //侦听子进程的message事件 worker_process.on('message’, function(msg) { if (msg.cmd && msg.cmd == ‘notifyRequest’) { data++; console.log('DATA VALUE : %d ', data);
} }); } } else { process.send({ cmd: ‘notifyRequest’ }); http.createServer(app).listen(app.get(‘port’), function () { console.log("Web server listening on port " + app.get(‘port’)); }); }

多进程起动 参考官网代码

因为 Session 无法 在多进程 之间共享的问题,造成系统Session登录后台无法 共享

后台经过 google baidu 终于 找到了解决办法

把 Session 用 redis 来存储

var RedisStore = require('connect-redis')(express);

app.use(express.session({
    secret:'xxz',
    store:new RedisStore(),
    key:'express.sid'
}));

最后终于搞定希望对大家有所帮助 哈哈

7 回复

嗯…

代码样式..

有代码的话用 ``` 包围吧

请问怎么使用sqlserver保存session

不好意思,我没有那个环境,没有用过!!

共享的话肯定需要持久存储… npm 上面很多… mongo 存储 (npm mongo-session) 可以试试…

回到顶部