限制maxsockets请求包

时间:2017-03-29 15:38:56

标签: node.js request

我尝试限制请求包maxsockets, 我使用fiddler来测试它使用并发的程度。

如我所见,它不适用我试图设定的10限制。

我不希望请求模块使用超过10个并发

我可能做错了什么?

process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
var loglar='idler2.txt';
var url = require('url');
var util = require('util');
var http = require('http');
var https = require('https');
var request = require('request');
var fs = require('fs');
var linkler = [];
var starttime = Math.round(new Date().getTime() / 1000);


http.globalAgent.maxSockets = 10;
https.globalAgent.maxSockets = 10;


var timeoutsure = 30 * 1000;
var success=0,fail=0;

process.on('exit', onExit);



function onExit() {
    console.log('\n%d secs,\n%d suc ,\n%d fail\n---------------------\n', 
    (Math.round(new Date().getTime() / 1000)) - starttime,success,fail);
}

function logla(data)
{
    var fd = fs.openSync(loglar, 'a+');
    fs.writeSync(fd, data);
    fs.closeSync(fd);
}

for(i=0;i<1000;i++)
{
    sorgutest();
}

var r = request.defaults({'proxy':'http://127.0.0.1:8888',pool: {maxSockets: 10}});

function sorgutest()
{

r.get({url:'https://freegeoip.net/json/',pool: {maxSockets: 10}}, function optionalCallback(err, httpResponse, body) {
  if (err) {
      fail++;
    return console.error('failed: 49', err);
  }
  else {
  try {bodyjson=JSON.parse(body);
  logla(body);
  success++;
  }
  catch(e){console.log("hamina 54");}
  }
});
}

fiddler nodejs test

1 个答案:

答案 0 :(得分:0)

如文件中所述:

  

请注意,如果您在循环中发送多个请求并创建多个新池对象,则maxSockets将无法按预期工作。要解决此问题,请将request.defaults与池选项一起使用,或者使用循环外部的maxSockets属性创建池对象。

尝试更改request.defaults的池选项或创建池对象并在所有请求调用上使用它。

编辑:

我注意到你已经使用了request.default,修复应该只是删除r.get调用中的pool选项。

自: r.get({url:'https://freegeoip.net/json/',pool: {maxSockets: 10}}, function optionalCallback(err, httpResponse, body) {

至:r.get({url:'https://freegeoip.net/json/'}, function optionalCallback(err, httpResponse, body) {