重复的http发布请求被延迟



我正试图通过post请求上传一个.zip文件(约180KB)作为八位字节流。以下代码按预期执行2-3次。文件被上传,我得到了预期的响应。

然而,当第3/4次发布数据时,请求在上传服务器上不会出现大约一分钟。当我等待一段时间时,我可以正常执行另外2-3次请求,然后再次延迟。

两台服务器都在本地主机(OS X)上运行node(v0.10.31)+express。

var options = {
    host : interface.host,
    port : interface.port,
    path : interface.path + '/deployResources',
    method : 'POST',
    headers : {
        'Content-Type': 'application/octet-stream',
        'Content-Length': byteLength,
        'Content-disposition': 'attachment; filename=resources.zip'
    }
};
var stream = fs.createReadStream(zipPath);
var req = http.request(options, function (res) {    
    // Response delayed on 3rd/4th run
    console.log(res.statusCode);    
});
stream.on('data', function (data) {
    req.write(data);
});
stream.on('end', function () {
    console.log('STREAM END');
    stream.close();
    req.end();
});

从节点v0.10.32更改日志:

http:不要在TE HEAD响应(Fedor Indutny)中发送0\r\n\r\n

这会是个问题吗?

谢谢。

有时使用Http.Agent可能会导致这样的问题。当您遇到这种行为时,您可以在请求选项中设置agent: false,以便请求始终获得全新的网络连接。

如果您在短时间内发出许多请求,这样做可能并不总是可取的,因为这可能会导致可用的文件描述符用完(Http.Agent旨在帮助防止这种情况)。在这种情况下,您可以尝试仅增加agent.maxSockets

相关内容

  • 没有找到相关文章

最新更新