2

我的 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,则客户端无法连接到服务器。

我该如何解决?帮我。

4

1 回答 1

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问题,这应该可以解决问题。但是,您也可以等待并希望这将出现在下一个版本中。

于 2015-10-14T21:08:01.187 回答