Node.js + Socket.io,已建立的连接正在增加

时间:2015-07-16 06:13:35

标签: node.js networking amazon-web-services socket.io connection-leaks

我的node.js + socket.io服务器已通过aws ec2实例进行部署。

并且有一些网络调整配置。

echo 1024 65535 > /proc/sys/net/ipv4/ip_local_port_range

echo 60 > /proc/sys/net/ipv4/tcp_keepalive_time
echo 10 > /proc/sys/net/ipv4/tcp_keepalive_intvl
echo 3 > /proc/sys/net/ipv4/tcp_keepalive_probes

echo 10 > /proc/sys/net/ipv4/tcp_fin_timeout
echo 20000 > /proc/sys/net/core/netdev_max_backlog
echo 2048 > /proc/sys/net/core/somaxconn
echo 0 > /proc/sys/net/ipv4/tcp_tw_reuse

我用netstat命令监视连接状态。

netstat -anl | grep ":22000" | awk '/^tcp/ {t[$NF]++}END{for(state in t){print state, t[state]} }'
然后,发现“ESTABLISHED”连接正在稳步增加。

TIME_WAIT 12
ESTABLISHED 304
LAST_ACK 1
LISTEN 1

如何检测异常连接并断开连接?

如果已建立的状态连接超过4000,则客户端无法连接到服务器。

我该如何解决?帮助我。

1 个答案:

答案 0 :(得分:0)

显然这是由ping超时引起的。

可能有帮助的修复方法是: node_modules / socket.io / node_modules / engine.io / LIB / socket.js

找到这个:

Socket.prototype.setPingTimeout = function () {
  var self = this;
  clearTimeout(self.pingTimeoutTimer);
  self.pingTimeoutTimer = setTimeout(function () {
    self.transport.close();
    self.onClose('ping timeout');
  }, self.server.pingInterval + self.server.pingTimeout);
};

添加自称为self.transport.close();

的行

根据socket.io的github问题,这应该解决问题。但是,您也可以等待并希望这将在下一个版本中发布。