node.js 需要太多的 TCP 套接字
node.js requires too many TCP sockets
我对node.js很陌生(通常是服务器问题的初学者)。
我设法运行我的节点.js应用程序并将其放在我的虚拟服务器(Linux 8.0)上。
问题是节点.js打开了很多TCP套接字。 一段时间后,允许的套接字数量耗尽,服务器崩溃。 我目前必须手动停止并重新启动节点进程以防止这种情况。 重新启动将重置 TCP 套接字。
我需要找到解决此问题的方法,因为手动重新启动它不是一个长期的解决方案,特别是如果访问者数量会增加并且我可能需要每 12 小时重新启动一次它(这是不切实际的)。
我可能在编码中做错了什么,但我目前不知道我可以优化什么。 我很高兴它甚至有效。 代码的哪一部分正在创建所有这些TCP连接? 我该如何解决这个问题?
我的节点文件/应用程序执行以下操作:
- 向公开和/或私人聊天发送/发送消息。
- 发送/发出游戏邀请(游戏类型不重要)
- 如果邀请接受邀请,则两个"客户"将被发送到同一个房间和游戏开始
节点服务器.js
var socket = require( 'socket.io' );
var express = require( 'express' );
var http = require( 'http' );
var app = express();
var server = http.createServer( app );
var io = socket.listen( server );
// handle incoming connections from clients
io.sockets.on( 'connection', function( client ) {
// Message Emit for match invite
client.on( 'sendmatchinvite', function( data ) {
console.log( 'Match invite for '+data.opponent+' from '+data.sender);
client.broadcast.emit('sendmatchinvite', { tmpmatch:data.tmpmatch, recepient: data.opponent, sender: data.sender } );
});
// Answer of invite
client.on( 'checkinviteanswer', function( data ) {
console.log( 'Invitation '+data.answer+' from '+data.id+' in '+data.room);
client.broadcast.to(data.room).emit('checkinviteanswer', { host:data.host } );
});
// Register Room
client.on('room', function(room) {
console.log( 'Client joined the room: '+room);
client.join(room);
});
// Score Emit for online games
client.on( 'score', function( data ) {
console.log( 'New Score for "'+data.game+'" (from '+data.player+') : ' + data.score + ' (Undo='+data.undo+') in room '+data.room);
client.broadcast.to(data.room).emit('score', { game:data.game, score: data.score, undo: data.undo, player: data.player } );
});
// Message Emit for private chat
client.on( 'privatemessage', function( data ) {
console.log( 'New Message for "'+data.recepient+'" (from '+data.sender+') : ' + data.text);
client.broadcast.emit('privatemessage', { text:data.text, recepient: data.recepient, sender: data.sender } );
});
// Message Emit for Player Room (all)
client.on( 'openmessage', function( data ) {
console.log( 'New Message for "Player Room" (from '+data.senderId+') : ' + data.text);
client.broadcast.emit('openmessage', { text:data.text, senderId:data.senderId, senderAvatar:data.senderAvatar, senderName:data.senderName, senderAvg:data.senderAvg, senderCam:data.senderCam, senderTimestamp:data.senderTimestamp, senderTime:data.senderTime } );
});
});
server.listen( 8080 );
如果我做一个lsof -ni -P
来查看连接,节点确实有很多行
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
...
node 13855 root 273u IPv4 33761866321 0t0 TCP 83.256.77.109:8080->84.60.76... (ESTABLISHED)
node 13855 root 275u IPv4 33781428883 0t0 TCP 83.256.77.109:8080->94.197.121...(ESTABLISHED)
node 13855 root 276u IPv4 33937034956 0t0 TCP 83.256.77.109:8080->79.195.169... (ESTABLISHED)
node 13855 root 278u IPv4 33971290522 0t0 TCP 83.256.77.109:8080->111.254.157... (ESTABLISHED)
node 13855 root 279u IPv4 33198279063 0t0 TCP 83.256.77.109:8080->91.48.115... (ESTABLISHED)
...
编辑 1
我应该注意我使用php页面。 在所有需要节点应用程序的php页面上,我都与节点服务器建立了连接。
var socket = io.connect( 'http://example.com:8080' );
socket.on('connect', function( data ) { });
我不确定这是否是正确的方法,因为在每次刷新页面时,连接都会关闭并重新建立。
首先,确保正确配置服务器。现代 Linux 具有保守的默认值,这些默认值未针对高同时连接进行优化。这里有一些提示:
可以连接多少个套接字?
其次,确保你有办法"踢"用户。例如,有人可能会在咖啡店使用手机或笔记本电脑进行连接,然后关闭设备。如果没有流量,TCP 连接可以保持打开状态数小时或数天。 如果您不主动检测它们,它们将慢慢切断所有有效的 TCP 连接。
相关文章:
- 如何使用HTML5与UDP套接字通信
- 在node.js中写入ECONNRESET错误和套接字连接检查
- java,javascript签名的小程序(文件选择,ftp上传)安全性/套接字异常
- 套接字服务器向客户端广播,但不从两者接收
- 如何确定套接字中的变量是否匹配
- node.js 需要太多的 TCP 套接字
- 从html页面通过node.js tcp套接字发送数据
- 从Firefox插件打开TCP套接字
- 使用 nodejs 通过 tcp 套接字传输数据
- TCP 套接字镶边
- Node.js 中的 TCP 套接字和文件操作
- 通过 TCP 套接字将权重 -> NodeJS 缩放为 Angular 的 JSON
- 如何通过节点网络套接字连接ruby TCP服务器
- C#Tcp服务器-HTML5网络套接字通信
- 将基于java线程的tcp套接字服务器转换为javascript异步tcp套接字服务器
- 有没有办法用JavaScript编写TCP服务器套接字?
- 通过TCP套接字发送mp3文件
- 用python编写的类似javascript的TCP套接字客户端
- 如何从另一个套接字访问tcp套接字
- 如果一个应用程序打开了2个TCP套接字,是否在这两个套接字之间都保持有序属性?