当服务器一次发送超过1000条消息时,无法捕获> 1000条消息nodejs udp

时间:2013-06-20 16:08:46

标签: node.js udp

我编写应用程序以通过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。

如何从发件人接收所有数据?

1 个答案:

答案 0 :(得分:1)

Node.js受底层操作系统的限制。操作系统对进程可以同时保留的未完成句柄数量进行限制。

您可能正在耗尽可用文件描述符的数量。我建议使用连接池来减少应用程序尝试使用的文件描述符的数量。因此,不要一次尝试发送1000个内容,而是将程序限制为一次100个连接池。

通过npm可以使用多个连接池库 - 一个流行的选择是poolr