我的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,则客户端无法连接到服务器。
我该如何解决?帮助我。
答案 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问题,这应该解决问题。但是,您也可以等待并希望这将在下一个版本中发布。