我们有一个使用 SocketIO 运行的 NodeJS 应用程序,并在 heroku 上进行集群。为了让 SocketIO 工作,我们使用这里讨论的 redis-adapter:https ://socket.io/docs/using-multiple-nodes/ 。
然后我们实现了粘性会话,如粘性会话文档所示:https ://github.com/elad/node-cluster-socket.io 。
事实证明,当我们部署到 Heroku 时,connection.remoteAddress 位于:
// Create the outside facing server listening on our port.
var server = net.createServer({ pauseOnConnect: true }, function(connection) {
// We received a connection and need to pass it to the appropriate
// worker. Get the worker for this connection's source IP and pass
// it the connection.
var index = worker_index(connection.remoteAddress, num_processes);
var worker = workers[index];
worker.send('sticky-session:connection', connection);
}).listen(port);
实际上是一些heroku路由服务器的IP地址,而不是客户端IP。我已经看到请求标头“x-forwarded-for”可以用于获取客户端IP,但是当我们以这种方式暂停连接时,我们甚至没有标头吗?