2

我有一个使用 Node.js 将数据从一个客户端传输到另一个客户端的发布/订阅模型。此外,服务器还记录接收到的所有内容并将其发送给新客户端。

但是,某些数据在传输时损坏,并且出现如下错误:

Error with socket!
{ [Error: write EPIPE] code: 'EPIPE', errno: 'EPIPE', syscall: 'write' }
Error with socket!
{ [Error: read ETIMEDOUT] code: 'ETIMEDOUT', errno: 'ETIMEDOUT', syscall: 'read' }

我不知道如何正确处理这些错误。客户端好像挂了。

由于服务器只是像服务器一样的代理,它并不真正知道数据是什么意思。在遇到这些错误之前,我不知道如何验证每个数据包。

这是我的代码:

// server is an object inheriting from net.Server
server.on('listening', function() {
    var port = server.address().port;
}).on('connection', function(cli) {
    cli.socketBuf = new Buffers();
    cli.commandStarted = false;
    cli.dataSize = 0;
    cli.setKeepAlive(true, 10*1000);
    cli.setNoDelay(true);
    cli.on('connect', function() {
        server.clients.push(cli);
    }).on('close', function() {
        var index = server.clients.indexOf(cli);
        server.clients.splice(index, 1);
    }).on('data', function (buf) {
        server.emit('data', cli, buf);
        if(op.autoBroadcast) {
            _.each(server.clients, function(c) {
                if(c != cli) c.write(buf);
            });
        }
    }).on('error', function(err) {
        console.log('Error with socket!');
        console.log(err);
    });
}).on('error', function(err) {
    console.log('Error with server!');
    console.log(err);
});

// ...

// room.dataSocket is an instance of server beyond
room.dataSocket.on('data', function(cli, d) {
    // bf is a buffered file
    bf.append(d);
    room.dataFileSize += d.length;
    
}).on('connection', function(con){
    bf.readAll(function(da) {
        con.write(da);
    });
});
4

1 回答 1

2

如果您在写入时收到 EPIPE 或任何错误,则表明对等方已关闭或连接已断开。所以你必须在那个时候关闭连接。

如果您收到读取超时,则推断是您设置了不切实际的短超时,或者对等方未能及时交付:在第二种情况下,您应该再次假设连接已关闭,然后关闭它。

于 2013-02-20T04:36:51.863 回答