我正试图通过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
。