- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我使用了ubuntu(12.04) + nodejs (v0.10.22) + socket.io (v0.9.14) 来传输消息。
大约有 300 个同时连接。几个小时后(大约 1 或 2 小时以上,它不会立即显示),一些连接将持续处于 CLOSE_WAIT 或 FIN_WAIT2 状态。
并且这些不死连接随着时间线性增长。当连接数达到限制(默认1024)时,用户将难以连接套接字服务器,除非某些连接正常释放。
下面是socket服务连接状态,运行了大约3个小时。
netstat -anl | grep <PORT_OF_NODE_PROCESS> | awk '/^tcp/ {t[$NF]++}END{for(state in t){print state, t[state]} }'
FIN_WAIT2 23
LISTEN 1
CLOSE_WAIT 27
TIME_WAIT 12
ESTABLISHED 333
FIN_WAIT1 12
使用 Nodemon Package运行js文件,当修改文件的最后修改时间时,nodemon会重启服务,并释放之前所有未死连接(CLOSEWAIT或FINWAIT2)
sudo vim /etc/security/limits.conf
* soft nofile 1024
* hard nofile 2048
root soft nofile 4096
root hard nofile 8192
user1 soft nofile 2048
user1 hard nofile 2048
尽量让连接难以达到极限。
让操作系统在短时间内自动关闭连接,我还没试过。
我找到了一些可能的解决方案来解决这个问题。但是上述解决方案并没有真正解决持久连接状态为CLOSE_WAIT或FIN_WAIT2的问题。我发现这是服务器 (CLOSE_WAIT) 或客户端 (FIN_WAIT2) 未正确关闭连接的结果。我认为 socket.io 会在超时后强制关闭这些不正确的连接。但它似乎无法正常工作。
我尝试在我的测试环境中重现状态 CLOSE_WAIT 或 FIN_WAIT2 问题。但它从不显示这些连接情况。
我发现之前有人问过相关问题(Many stale connections in state CLOSE_WAIT and FIN_WAIT2),但仍然找不到解决方案。有谁知道如何解决这个问题??
谢谢
最佳答案
我尝试同时使用多个连接来连接套接字服务器,我发现一些客户端套接字会使用相同的SOCKET ID(从xhr获取,它看起来像 nmXTMmCGNQp4EncrfHqj)建立连接。我在所有连接建立后关闭浏览器,它会导致许多 CLOSE_WAIT 连接没有释放。一些连接将关闭(基于已生成的Unique SOCKET ID 的数量)。因为服务器将从 SOCKET ID 建立 TCP/IP 连接。但是,如果 SOCKET ID 连接已经存在于连接池中,则该连接将不会存储在连接池中。因此,当客户端发送 FIN 数据包尝试关闭连接但不存在于服务器连接池中时。服务器永远不会发送ACK包来准备关闭连接。所以这些连接会一直处于CLOSE_WAIT状态,不会释放。
var host = 'http://socket.server/';
var sockets = [];
for(var i=0;i<200;i++){
var socket = io.connect(host,{"force new connection":true});
sockets.push(socket);
socket.on("message",function(message){
console.log(message);
});
socket.on("disconnect",function(){
console.log("disconnect");
});
}
修复 lib\manager.js 第 670 行。
当连接池中已存在SOCKET ID连接时,不从SOCKET ID建立TCP/IP连接。
另请参阅:https://github.com/kejyun/socket.io/commit/8d6c02a477d365f019530b4ec992420dfb90eb09
if (!this.connected[data.id]) {
if (transport.open) {
if (this.closed[data.id] && this.closed[data.id].length) {
transport.payload(this.closed[data.id]);
this.closed[data.id] = [];
}
this.onOpen(data.id);
this.store.publish('open', data.id);
this.transports[data.id] = transport;
}
this.onConnect(data.id);
this.store.publish('connect', data.id);
//....etc
}
}
下面是socket服务连接状态,运行了大约6个小时。
netstat -anl | grep <PORT_OF_NODE_PROCESS> | awk '/^tcp/ {t[$NF]++}END{for(state in t){print state, t[state]} }'
FIN_WAIT2 37
LISTEN 1
TIME_WAIT 13
ESTABLISHED 295
FIN_WAIT1 20
关于node.js - NodeJS 套接字 : Many connections in state CLOSE_WAIT and FIN_WAIT2 without release,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20777827/
我正在编写一个简单的有限状态机,并意识到在某些情况下,事件可以将状态变为多个可能的结果。基本上,从状态 A,如果事件 E 发生,状态可能是 C 或 D。 我目前正在使用此处编写的 Javascript
我在 React 中构建了一个应用程序,我在其中一个样板项目中找到了一行。 (state = {}) => state 谁能给我解释一下上面这行是什么意思?它是 javascript ES6 标准。
如何将多个状态变量组合成另一个? 我想通过一些用户交互来更改高度或宽度的值,并相应地更新 View 中的所有内容。所以高度或宽度会改变,面积也会改变。 我想它看起来像这样 @State var wid
我的容器正在通过 redux store 获取状态。 我通过这样的 Prop 将这个状态传递给模态框:示例: render(){ let {team,id} =this.props.data;
您好,我正在尝试使用 map 根据我所在状态的数组渲染选项,但在返回中使用它时我得到未定义 这是数组 this.state = { countries: ["Australia","Brazil"
我想将 this.state.currentPlayer 分配给 this.state.whosPlaying。它抛出错误TypeError:无法读取新板上未定义的属性“currentPlayer”。
我正在实现某种动态工作流程,当达到某个点时,我必须重新加载状态以呈现 HTML 并重新实例化 Controller 才能继续。 我发现我第二次调用 $state.reload() 不起作用。这是期望的
我正在开发一个 flutter 应用程序,并发现状态管理出现意外行为。我创建了一个示例应用来重现该行为,您可以在下面找到代码和日志输出。 该应用程序包含一个简单的 ListView,其中包含 10 个
有人可以举一个简单的例子,其中 state monad 比直接传递 state 更好吗? bar1 (Foo x) = Foo (x + 1) 对比 bar2 :: State Foo Foo bar
我想写类似 $state.go("/spheres/{{$stateParams.sphereId}}/mono/view"); 的内容使用外部 url 而不是状态,但这不起作用:( 现在我明白为什么
我正在使用“angular-ui-tree”:“^2.22.5” 点击执行某事菜单项时出错.. TypeError: this.$state is undefined 如何将对 $state 的引用传
我在elasticsearch中有文本字段,我想在kibana上可视化词云... 第一步,我们需要标记它们,我使用了“标准标记器” ... 使用这种形式的词云可视化结果如下图所示: 但是我需要的是专有
我正在尝试以编程方式在状态之间移动(使用 ui.router),而用户无需单击任何内容。文档位于 http://angular-ui.github.io/ui-router/site/#/api/ui
我想编写像“(event, state) -> state”这样的折叠函数。如果Java中没有任何模式匹配且不可变,我该如何编写它? 最佳答案 我认为您正在寻找 Java 中的函数式编程。 此版本中引
这个问题已经有答案了: What does an exclamation mark before a variable mean in JavaScript (4 个回答) 已关闭 8 年前。 您好,
https://plnkr.co/edit/bOZW1a9u62W1QA6cYjYj?p=preview 预期 登录后,所有 $states 都会初始化,然后单击 Ticker 按钮后,唯一应重新初始
试图决定(针对我的应用程序)在 onPause() 中保存什么以及要保存在 onSaveInstanceState() 中的内容,我梳理了整个 SO 以获得提示和明确的指导方针。 如果我没理解错的话,
在 Javascript 中,当我单击滚动条(页面中出现的任何滚动条)并将鼠标悬停在图像上时,图像再次开始拖动。 图像只能在鼠标按钮按下状态下拖动。 所以我试图通过了解鼠标按钮状态(mousedown
我见过 Maybe和 Either在代码中使用仿函数(和应用)是有道理的,但我很难想出一个 State 的例子。仿函数和应用。也许它们不是很有用,只是因为 State 才存在。 monad 需要一个仿
我非常努力地想围绕 State Monad,但我不明白以下内容: 鉴于 return 的实现和 (>>=) ,当你说 State $ \s ->.... ,在哪里s来自?我的意思是,当你开始表演时 >
我是一名优秀的程序员,十分优秀!