我有以下设置:
node.js 客户端向 node.js 服务器发出端到端请求。不到一分钟后,客户端失败并出现错误 ENOBUFS。
客户:
(function(){
var loadUrl=function(){
var http=require('http');
var querystring=require('querystring');
var options = {host:"localhost",port:1337,path:'/post',method:'POST'};
var req = http.request(options, function(res){
res.setEncoding('utf8');
var body='';
res.on('data', function (chunk) {
body+=chunk;
});
res.on('end', function (chunk) {
loadUrl();
});
});
req.on('error', function(e) {
console.log('problem with request: ' + e.message);
});
var post_data = querystring.stringify({id:0});
req.write(post_data);
req.end();
}
setTimeout(loadUrl,1000);
})()
服务器:
var http = require('http');
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World\n');
}).listen(1337, '127.0.0.1');
而 this question类似,我将其发布为原始问题的概括(我使用的是 post 而不是 get),并带有一个测试用例。
最佳答案
问题似乎是 Node.js HTTP 客户端连接池的问题。
如果将选项 agent:false
添加到 http.request()
function 的 options
参数中它将禁用连接池并让每个请求使用 header Connection: close
。此更改似乎允许客户端代码无限期运行。
var options = {agent:false, host:"localhost", port:1337, /*...*/ };
这样做会降低 HTTP 客户端的性能,并且您应该会看到客户端进程频繁暂停(可能是在 V8 运行时进行垃圾收集时)。但它似乎确实解决了你的问题!
根据@joshp 的评论,查看此问题是否已在更高版本的 Node.js 中得到解决,或者考虑提交错误报告。
关于javascript - 非常简单的 Node.js 客户端在多次 http 请求后抛出错误 ENOBUFS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10603860/