我编写应用程序以通过nodejs发送文件多播 我按块读取文件并像块一样发送它
for (var block = 1; block <= number_of_block; block++) {
sendBlock(FILEPATH, block)
函数sendBlock by CHUNK
function sendBlock(file, block) {
fs.open(file, 'r', function(err, fp) {
if (err) {
return;
}
var buf = new Buffer(4 + CHUNK_SIZE);
fs.read(fp, buf, 4, CHUNK_SIZE, (block - 1) * CHUNK_SIZE, function(err, bytesRead) {
if (err) {
}
buf[0] = 0;
buf[1] = opcodes.OPCODE_DATA;
buf[2] = (block >> 8) & 0xFF;
buf[3] = block & 0xFF;
udpserver.send(buf, 0, 4 + bytesRead, PORT, MULTICAST_IP_ADDRESS);
fs.close(fp);
});
});
我创建客户端以接收消息
fs.open(fileName, 'a', function(e, id) {
if (4 + CHUNK_SIZE > message.length) {
fs.write(fd, message, 4, message.length - 4, (block - 1) * CHUNK_SIZE, function() {
fs.close(fd, function() {
console.log('file closed', block);
send("miss block:" + missArray);
});
});
} else {
console.log("message length:", message.length)
console.log((block - 1) * CHUNK_SIZE)
fs.write(fd, message, 4, CHUNK_SIZE, (block - 1) * CHUNK_SIZE, function() {
fs.close(fd, function() {
console.log('1file closed', block);
if (block % NUMBER_BLOCK == 0) {
if (blockArray.length > 0) {
missArray = missArray.concat(blockArray);
}
blockArray = range(block + 1, NUMBER_BLOCK)
}
//udpserver.send(block+1)
});
});
}
});
但是当服务器发送超过1000个消息时,客户端无法捕获所有内容 服务器发送
block -- 6907
block -- 6908
block -- 6909
block -- 6910
block -- 6911
block -- 6912
block -- 6913
客户启发和写作
block ------ 1008
block ------ 1009
block ------ 1010
block ------ 1011
我测试要接收的最大文件是10.4 MB。
如何从发件人接收所有数据?
答案 0 :(得分:1)
Node.js受底层操作系统的限制。操作系统对进程可以同时保留的未完成句柄数量进行限制。
您可能正在耗尽可用文件描述符的数量。我建议使用连接池来减少应用程序尝试使用的文件描述符的数量。因此,不要一次尝试发送1000个内容,而是将程序限制为一次100个连接池。
通过npm可以使用多个连接池库 - 一个流行的选择是poolr。