我在使用Node.js、socket.io和node.js集群来对我的应用进行集群处理时遇到了问题。
我正在使用socket.io-redis来共享所有工作进程的信息,但是它无法正常工作。
以下是我的代码:
var cluster = require('cluster');
var numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
// Fork workers.
for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('exit', function(worker, code, signal) {
console.log('worker ' + worker.process.pid + ' died');
});
} else {
...
var express = require("express");
//Server
var server = express();
//Socket.io
var http = require('http').Server(server);
var io = require('socket.io')(http);
var redis_io = require('socket.io-redis');
var redis = require("redis");
io.adapter(redis_io({host: "127.0.0.1", port: 6379 }));
...
}
在客户端,我会在握手时遇到400错误或WebSocket在建立连接之前就关闭的错误。
我该怎么做才能解决这个问题呢?
我正在使用最新版本的node.js和socket.io。
谢谢!